[PDF/SVG PCB Print] Implemented sub-PCBs
This commit is contained in:
parent
6d8ca3f163
commit
71f2894ef4
|
|
@ -54,12 +54,14 @@ class Any_PCB_PrintOptions(VariantOptions):
|
||||||
super().config(parent)
|
super().config(parent)
|
||||||
self.drill_marks = DRILL_MARKS_MAP[self.drill_marks]
|
self.drill_marks = DRILL_MARKS_MAP[self.drill_marks]
|
||||||
|
|
||||||
def filter_components(self, force_copy):
|
def filter_components(self):
|
||||||
if not self._comps and not force_copy:
|
if not self.will_filter_pcb_components() and self.title == '':
|
||||||
return GS.pcb_file, None
|
return GS.pcb_file, None
|
||||||
self.filter_pcb_components(GS.board)
|
self.filter_pcb_components(GS.board)
|
||||||
|
self.set_title(self.title)
|
||||||
# Save the PCB to a temporal dir
|
# Save the PCB to a temporal dir
|
||||||
fname, pcb_dir = self.save_tmp_dir_board('pdf_pcb_print')
|
fname, pcb_dir = self.save_tmp_dir_board('pdf_pcb_print')
|
||||||
|
self.restore_title()
|
||||||
self.unfilter_pcb_components(GS.board)
|
self.unfilter_pcb_components(GS.board)
|
||||||
return fname, pcb_dir
|
return fname, pcb_dir
|
||||||
|
|
||||||
|
|
@ -86,8 +88,7 @@ class Any_PCB_PrintOptions(VariantOptions):
|
||||||
cmd.extend(['--color_theme', self.color_theme])
|
cmd.extend(['--color_theme', self.color_theme])
|
||||||
if svg:
|
if svg:
|
||||||
cmd.append('--svg')
|
cmd.append('--svg')
|
||||||
self.set_title(self.title)
|
board_name, board_dir = self.filter_components()
|
||||||
board_name, board_dir = self.filter_components(self.title != '')
|
|
||||||
cmd.extend([board_name, os.path.dirname(output)])
|
cmd.extend([board_name, os.path.dirname(output)])
|
||||||
cmd, video_remove = add_extra_options(cmd)
|
cmd, video_remove = add_extra_options(cmd)
|
||||||
# Add the layers
|
# Add the layers
|
||||||
|
|
@ -96,7 +97,6 @@ class Any_PCB_PrintOptions(VariantOptions):
|
||||||
cmd.append('Edge.Cuts')
|
cmd.append('Edge.Cuts')
|
||||||
# Execute it
|
# Execute it
|
||||||
ret = exec_with_retry(cmd)
|
ret = exec_with_retry(cmd)
|
||||||
self.restore_title()
|
|
||||||
# Remove the temporal PCB
|
# Remove the temporal PCB
|
||||||
if board_dir:
|
if board_dir:
|
||||||
logger.debug('Removing temporal variant dir `{}`'.format(board_dir))
|
logger.debug('Removing temporal variant dir `{}`'.format(board_dir))
|
||||||
|
|
|
||||||
|
|
@ -716,8 +716,12 @@ class VariantOptions(BaseOptions):
|
||||||
dest = os.path.join(d, os.path.basename(GS.pcb_file))
|
dest = os.path.join(d, os.path.basename(GS.pcb_file))
|
||||||
self._sub_pcb.load_board(dest)
|
self._sub_pcb.load_board(dest)
|
||||||
|
|
||||||
|
def will_filter_pcb_components(self):
|
||||||
|
""" True if we will apply filters/variants """
|
||||||
|
return self._comps or self._sub_pcb
|
||||||
|
|
||||||
def filter_pcb_components(self, board, do_3D=False, do_2D=True, highlight=None):
|
def filter_pcb_components(self, board, do_3D=False, do_2D=True, highlight=None):
|
||||||
if not self._comps and not self._sub_pcb:
|
if not self.will_filter_pcb_components():
|
||||||
return False
|
return False
|
||||||
if self._comps:
|
if self._comps:
|
||||||
self.comps_hash = self.get_refs_hash()
|
self.comps_hash = self.get_refs_hash()
|
||||||
|
|
|
||||||
|
|
@ -0,0 +1,17 @@
|
||||||
|
# Example KiBot config file
|
||||||
|
kibot:
|
||||||
|
version: 1
|
||||||
|
|
||||||
|
import:
|
||||||
|
- file: battery_pack_sub_pcbs.kibot.yaml
|
||||||
|
|
||||||
|
outputs:
|
||||||
|
- name: 'print_front'
|
||||||
|
comment: "Print F.Cu+F.SilkS"
|
||||||
|
type: pdf_pcb_print
|
||||||
|
dir: Layers
|
||||||
|
options:
|
||||||
|
title: 'Fake title for front copper and silk (%S)'
|
||||||
|
layers:
|
||||||
|
- layer: F.Cu
|
||||||
|
- layer: F.SilkS
|
||||||
Loading…
Reference in New Issue