forked from edwardvmills/Silk
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathControlPoly6.py
122 lines (111 loc) · 4.72 KB
/
ControlPoly6.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
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
# This file is part of Silk
# (c) Edward Mills 2016-2017
# edwardvmills@gmail.com
#
# 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 ControlPoly6():
def Activated(self):
sel=Gui.Selection.getSelection()
if len(sel)==1:
try:
if sel[0].Shape.Curve.NbPoles==4:
mode='Bezier'
except Exception:
pass
try:
if sel[0].GeometryCount==5L:
mode='5L'
except Exception:
pass
try:
if sel[0].GeometryCount!=5L:
#if isinstance(sel[0].Geometry[0], Part.ArcOfCircle):
mode='FirstElement'
except Exception:
pass
if len(sel)==2:
if sel[0].TypeId=='Sketcher::SketchObject' and sel[1].TypeId=='Sketcher::SketchObject':
mode='2N'
try:
if sel[0].Shape.Curve.NbPoles==4 and sel[1].Shape.Curve.NbPoles==4:
mode='FilletBezier'
except Exception:
pass
print 'selection processed as ', mode, ' operation'
if mode=='5L':
sketch=Gui.Selection.getSelection()[0]
a=FreeCAD.ActiveDocument.addObject("Part::FeaturePython","ControlPoly6_5L")
AN.ControlPoly6_5L(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","ControlPoly6_FirstElement")
AN.ControlPoly6_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=='Bezier':
bezier=Gui.Selection.getSelection()[0]
a=FreeCAD.ActiveDocument.addObject("Part::FeaturePython","ControlPoly6_Bezier")
AN.ControlPoly6_FirstElement(a,bezier)
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","ControlPoly6_2N")
AN.ControlPoly6_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()
if mode=='FilletBezier':
CubicCurve4_0=Gui.Selection.getSelection()[0]
CubicCurve4_1=Gui.Selection.getSelection()[1]
a=FreeCAD.ActiveDocument.addObject("Part::FeaturePython","ControlPoly6_FilletBezier")
AN.ControlPoly6_FilletBezier(a,CubicCurve4_0,CubicCurve4_1)
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 + '/ControlPoly6.svg', 'MenuText': 'ControlPoly6', 'ToolTip': 'ControlPoly6'}
Gui.addCommand('ControlPoly6', ControlPoly6())