add bt_player
This commit is contained in:
193
kicad_plugins/rf_tools_wizards/uwArcPrimitive_wizard.py
Normal file
193
kicad_plugins/rf_tools_wizards/uwArcPrimitive_wizard.py
Normal file
@@ -0,0 +1,193 @@
|
||||
# This program 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 2 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, write to the Free Software
|
||||
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
|
||||
# MA 02110-1301, USA.
|
||||
#
|
||||
|
||||
# This python script wizard creates an arc track for microwave applications
|
||||
# Author easyw
|
||||
# taskkill -im pcbnew.exe /f & C:\KiCad-v5-nightly\bin\pcbnew
|
||||
|
||||
from __future__ import division
|
||||
|
||||
import math, cmath
|
||||
|
||||
from pcbnew import *
|
||||
import pcbnew
|
||||
import FootprintWizardBase
|
||||
|
||||
|
||||
class uwArcPrimitive_wizard(FootprintWizardBase.FootprintWizard):
|
||||
|
||||
def GetName(self):
|
||||
return "uW Arc Pad"
|
||||
|
||||
def GetDescription(self):
|
||||
return "uW Arc Pad Footprint Wizard"
|
||||
|
||||
def GenerateParameterList(self):
|
||||
|
||||
self.AddParam("Corner", "width", self.uMM, 1.319)
|
||||
self.AddParam("Corner", "radius", self.uMM, 5.0, min_value=0, designator='r', hint="Arc radius")
|
||||
self.AddParam("Corner", "angle", self.uDegrees, 90, designator='a')
|
||||
self.AddParam("Corner", "square_end", self.uBool, False)
|
||||
self.AddParam("Corner", "solder_clearance", self.uMM, 0.0)
|
||||
self.AddParam("Corner", "linear", self.uBool, False)
|
||||
|
||||
def CheckParameters(self):
|
||||
|
||||
pads = self.parameters['Corner']
|
||||
|
||||
|
||||
def GetValue(self):
|
||||
name = "{0:.2f}_{1:0.2f}_{2:.0f}".format(pcbnew.ToMM(self.parameters["Corner"]["width"]),pcbnew.ToMM(self.parameters["Corner"]["radius"]),(self.parameters["Corner"]["angle"]))
|
||||
if not self.parameters["Corner"]["linear"]:
|
||||
pref = "uwArc"
|
||||
else:
|
||||
pref = "uwLine"
|
||||
if self.parameters["Corner"]["square_end"]:
|
||||
pref += "R"
|
||||
return pref + "%s" % name
|
||||
|
||||
def GetReferencePrefix(self):
|
||||
if not self.parameters["Corner"]["linear"]:
|
||||
pref = "uwA"
|
||||
else:
|
||||
pref = "uwL"
|
||||
#if self.parameters["Corner"]["rectangle"]:
|
||||
# pref += "R"
|
||||
return pref + "***"
|
||||
|
||||
# build a custom pad
|
||||
def smdCustomArcPad(self, module, size, pos, rad, name, angle_D, layer, ln, solder_clearance):
|
||||
if hasattr(pcbnew, 'D_PAD'):
|
||||
pad = D_PAD(module)
|
||||
else:
|
||||
pad = PAD(module)
|
||||
## NB pads must be the same size and have the same center
|
||||
pad.SetSize(size)
|
||||
#pad.SetSize(pcbnew.wxSize(size[0]/5,size[1]/5))
|
||||
pad.SetShape(PAD_SHAPE_CUSTOM) #PAD_RECT)
|
||||
pad.SetAttribute(PAD_ATTRIB_SMD) #PAD_SMD)
|
||||
#pad.SetDrillSize (0.)
|
||||
#Set only the copper layer without mask
|
||||
#since nothing is mounted on these pads
|
||||
pad.SetPos0(pos)
|
||||
pad.SetPosition(pos)
|
||||
pad.SetPadName(name)
|
||||
#pad.Rotate(pos, angle)
|
||||
pad.SetAnchorPadShape(PAD_SHAPE_CIRCLE) #PAD_SHAPE_RECT)
|
||||
if solder_clearance > 0:
|
||||
pad.SetLocalSolderMaskMargin(solder_clearance)
|
||||
pad.SetLayerSet(pad.ConnSMDMask())
|
||||
else:
|
||||
pad.SetLayerSet( LSET(layer) )
|
||||
|
||||
if not ln:
|
||||
pad.AddPrimitive(pcbnew.wxPoint(0,rad), pcbnew.wxPoint(0,0), int(angle_D*10), (size[0]))
|
||||
else:
|
||||
pad.AddPrimitive(pcbnew.wxPoint(0,0), pcbnew.wxPoint(rad,0), (size[0]))
|
||||
return pad
|
||||
|
||||
def smdPad(self,module,size,pos,name,ptype,angle_D,layer,solder_clearance,offs=None):
|
||||
if hasattr(pcbnew, 'D_PAD'):
|
||||
pad = D_PAD(module)
|
||||
else:
|
||||
pad = PAD(module)
|
||||
pad.SetSize(size)
|
||||
pad.SetShape(ptype) #PAD_SHAPE_RECT PAD_SHAPE_OVAL PAD_SHAPE_TRAPEZOID PAD_SHAPE_CIRCLE
|
||||
# PAD_ATTRIB_CONN PAD_ATTRIB_SMD
|
||||
pad.SetAttribute(PAD_ATTRIB_SMD)
|
||||
if solder_clearance > 0:
|
||||
pad.SetLocalSolderMaskMargin(solder_clearance)
|
||||
pad.SetLayerSet(pad.ConnSMDMask())
|
||||
else:
|
||||
pad.SetLayerSet( LSET(layer) )
|
||||
#pad.SetDrillSize (0.)
|
||||
#pad.SetLayerSet(pad.ConnSMDMask())
|
||||
pad.SetPos0(pos)
|
||||
pad.SetPosition(pos)
|
||||
#pad.SetOrientationDegrees(90-angle_D/10)
|
||||
pad.SetOrientationDegrees(angle_D)
|
||||
if offs is not None:
|
||||
pad.SetOffset(offs)
|
||||
pad.SetName(name)
|
||||
return pad
|
||||
|
||||
def BuildThisFootprint(self):
|
||||
|
||||
pads = self.parameters['Corner']
|
||||
|
||||
radius = pads['radius'] #outline['diameter'] / 2
|
||||
width = pads['width']
|
||||
sold_clear = pads['solder_clearance']
|
||||
line = pads['linear']
|
||||
|
||||
angle_deg = float(pads["angle"]) #*10)
|
||||
angle = math.radians(angle_deg) #/10) #To radians
|
||||
sign = 1.
|
||||
if angle < 0:
|
||||
sign = -1.
|
||||
|
||||
pos = pcbnew.wxPoint(0,0)
|
||||
offset1 = pcbnew.wxPoint(-sign*width/2,0)
|
||||
offset2 = pcbnew.wxPoint(0,0)
|
||||
module = self.module
|
||||
size_pad = pcbnew.wxSize(width, width)
|
||||
#size_pad = pcbnew.wxSize(width/5, width/5)
|
||||
module.Add(self.smdCustomArcPad(module, size_pad, pcbnew.wxPoint(0,0), radius, "1", (angle_deg), F_Cu, line, sold_clear))
|
||||
size_pad = pcbnew.wxSize(width, width)
|
||||
end_coord = (radius) * cmath.exp(math.radians(angle_deg-90)*1j)
|
||||
if pads['square_end'] or angle_deg == 0 or radius == 0:
|
||||
if not line:
|
||||
## NB pads must be the same size and have the same center
|
||||
module.Add(self.smdPad(module, size_pad, pcbnew.wxPoint(0,0), "1", PAD_SHAPE_RECT,0,F_Cu,sold_clear,offset1))
|
||||
else:
|
||||
module.Add(self.smdPad(module, size_pad, pcbnew.wxPoint(0,0), "1", PAD_SHAPE_RECT,0,F_Cu,sold_clear))
|
||||
if not line:
|
||||
#pos = pcbnew.wxPoint(end_coord.real+(sign*width/2)*math.cos(angle),end_coord.imag+(sign*width/2)*math.sin(angle)+radius)
|
||||
pos = pcbnew.wxPoint(end_coord.real,end_coord.imag+radius)
|
||||
module.Add(self.smdPad(module, size_pad, pos, "1", PAD_SHAPE_RECT,90-angle_deg,F_Cu,sold_clear,wxPoint(0,(sign*width/2))))
|
||||
#*math.sin(math.pi/2-angle),(sign*width/2)*math.cos(math.pi/2-angle))))
|
||||
else:
|
||||
pos = pcbnew.wxPoint(radius,0) #+width/2,0)
|
||||
module.Add(self.smdPad(module, size_pad, pos, "1", PAD_SHAPE_RECT,0,F_Cu,sold_clear))
|
||||
else:
|
||||
## NB pads must be the same size and have the same center
|
||||
#size_pad = pcbnew.wxSize(width/5, width/5)
|
||||
size_pad = pcbnew.wxSize(width, width)
|
||||
if not line:
|
||||
pos = pcbnew.wxPoint(end_coord.real,end_coord.imag+radius)
|
||||
else:
|
||||
pos = pcbnew.wxPoint(radius,0)
|
||||
module.Add(self.smdPad(module, size_pad, pos, "1", PAD_SHAPE_CIRCLE,0,F_Cu,sold_clear))
|
||||
|
||||
# Text size
|
||||
text_size = self.GetTextSize() # IPC nominal
|
||||
thickness = self.GetTextThickness()
|
||||
textposy = self.draw.GetLineThickness()/2 + self.GetTextSize()/2 + thickness #+ outline['margin']
|
||||
self.draw.Reference( 0, -textposy-width, text_size )
|
||||
if not line:
|
||||
self.draw.Value( 0, radius+textposy+width, text_size )
|
||||
else:
|
||||
self.draw.Value( 0, textposy+width, text_size )
|
||||
# set SMD attribute
|
||||
# set SMD attribute
|
||||
if hasattr(pcbnew, 'MOD_VIRTUAL'):
|
||||
module.SetAttributes(pcbnew.MOD_VIRTUAL)
|
||||
else:
|
||||
module.SetAttributes(pcbnew.FP_EXCLUDE_FROM_BOM | pcbnew.FP_EXCLUDE_FROM_POS_FILES)
|
||||
__version__ = 1.7
|
||||
self.buildmessages += ("version: {:.1f}".format(__version__))
|
||||
|
||||
uwArcPrimitive_wizard().register()
|
||||
Reference in New Issue
Block a user