forked from edwardvmills/Silk
-
Notifications
You must be signed in to change notification settings - Fork 0
/
ControlPoly4.py
81 lines (73 loc) · 3.5 KB
/
ControlPoly4.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
# This file is part of Silk
# (c) Edward Mills 2016-2017
#
# NURBS Surface modeling tools focused on low degree and seam continuity (FreeCAD Workbench)
#
# Silk 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 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 General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>.
from __future__ import division # allows floating point division from integers
import FreeCAD, Part, math
from FreeCAD import Base
from FreeCAD import Gui
import ArachNURBS as AN
# Locate Workbench Directory
import os, Silk_dummy
path_Silk = os.path.dirname(Silk_dummy.__file__)
path_Silk_icons = os.path.join( path_Silk, 'Resources', 'Icons')
class ControlPoly4():
def Activated(self):
sel=Gui.Selection.getSelection()
if len(sel)==1:
if sel[0].GeometryCount==3:
mode='3L'
else: #if sel[0].GeometryCount==1 or sel[0].GeometryCount==8:
mode='FirstElement'
elif len(sel)==2:
mode='2N'
print mode
if mode=='3L':
sketch=Gui.Selection.getSelection()[0]
a=FreeCAD.ActiveDocument.addObject("Part::FeaturePython","ControlPoly4_3L")
AN.ControlPoly4_3L(a,sketch)
a.ViewObject.Proxy=0 # just set it to something different from None (this assignment is needed to run an internal notification)
a.ViewObject.LineWidth = 1.00
a.ViewObject.LineColor = (0.00,1.00,1.00)
a.ViewObject.PointSize = 4.00
a.ViewObject.PointColor = (0.00,0.00,1.00)
FreeCAD.ActiveDocument.recompute()
if mode=='FirstElement':
sketch=Gui.Selection.getSelection()[0]
a=FreeCAD.ActiveDocument.addObject("Part::FeaturePython","ControlPoly4_FirstElement")
AN.ControlPoly4_FirstElement(a,sketch)
a.ViewObject.Proxy=0 # just set it to something different from None (this assignment is needed to run an internal notification)
a.ViewObject.LineWidth = 1.00
a.ViewObject.LineColor = (0.00,1.00,1.00)
a.ViewObject.PointSize = 4.00
a.ViewObject.PointColor = (0.00,0.00,1.00)
FreeCAD.ActiveDocument.recompute()
if mode=='2N':
sketch0=Gui.Selection.getSelection()[0]
sketch1=Gui.Selection.getSelection()[1]
a=FreeCAD.ActiveDocument.addObject("Part::FeaturePython","ControlPoly4_2N")
AN.ControlPoly4_2N(a,sketch0,sketch1)
a.ViewObject.Proxy=0 # just set it to something different from None (this assignment is needed to run an internal notification)
a.ViewObject.LineWidth = 1.00
a.ViewObject.LineColor = (0.00,1.00,1.00)
a.ViewObject.PointSize = 4.00
a.ViewObject.PointColor = (0.00,0.00,1.00)
FreeCAD.ActiveDocument.recompute()
def GetResources(self):
return {'Pixmap' : path_Silk_icons + '/ControlPoly4.svg', 'MenuText': 'ControlPoly4',
'ToolTip': 'ControlPoly4: \n Creates a 4 point control polygon from a variety of inputs. \n -a sketch of three lines connected end to end \n -two sketches containing a circle and a line each \n -if a single sketch is selected that does not contain \n three elements, the first element is converted \n (this works for line, arc of circle, and arc of ellipse elements)'}
Gui.addCommand('ControlPoly4', ControlPoly4())