From f6338c9ffb62a46eb18746e02bcf3d91ec3df3c1 Mon Sep 17 00:00:00 2001 From: Scott Bezek Date: Tue, 15 Feb 2022 13:05:24 -0800 Subject: [PATCH] Tweak PCB 3d renders --- .github/workflows/electronics.yml | 8 ++++---- electronics/scripts/export_3d.py | 12 ++++++++---- 2 files changed, 12 insertions(+), 8 deletions(-) diff --git a/.github/workflows/electronics.yml b/.github/workflows/electronics.yml index b54865c..55cb1cc 100644 --- a/.github/workflows/electronics.yml +++ b/.github/workflows/electronics.yml @@ -33,10 +33,10 @@ jobs: - name: Render PCB 3D [view_base] run: | - ./electronics/scripts/export_3d.py electronics/view_base/view_base.kicad_pcb --suffix front --width 1280 --height 1280 --skip-virtual --color-soldermask 0.95 0.95 0.95 --color-silk 0.1 0.1 0.1 --skip-raytrace transform z+ z+ + ./electronics/scripts/export_3d.py electronics/view_base/view_base.kicad_pcb --suffix front --width 1024 --height 1024 --skip-virtual --color-soldermask 1 1 1 --color-silk 0.1 0.1 0.1 transform z+ z+ rx+ rx+ rz- ry- ry- mu cp electronics/build/view_base-front-3d.png electronics/build/outputs ./scripts/annotate_image.sh electronics/build/outputs/view_base-front-3d.png - ./electronics/scripts/export_3d.py electronics/view_base/view_base.kicad_pcb --suffix back --width 1280 --height 1280 --skip-virtual --color-soldermask 0.95 0.95 0.95 --color-silk 0.1 0.1 0.1 --skip-raytrace transform z+ z+ ry+ ry+ ry+ ry+ ry+ ry+ ry+ ry+ ry+ ry+ ry+ ry+ ry+ ry+ ry+ ry+ ry+ ry+ + ./electronics/scripts/export_3d.py electronics/view_base/view_base.kicad_pcb --suffix back --width 1024 --height 1024 --skip-virtual --color-soldermask 1 1 1 --color-silk 0.1 0.1 0.1 transform z+ z+ ry+ ry+ ry+ ry+ ry+ ry+ ry+ ry+ ry+ ry+ ry+ ry+ ry+ ry+ ry+ ry+ ry+ ry+ rx+ rx+ rz- ry+ ry+ mu cp electronics/build/view_base-back-3d.png electronics/build/outputs ./scripts/annotate_image.sh electronics/build/outputs/view_base-back-3d.png env: @@ -56,10 +56,10 @@ jobs: - name: Render PCB 3D [view_screen] run: | - ./electronics/scripts/export_3d.py electronics/view_screen/view_screen.kicad_pcb --suffix front --width 1280 --height 1280 --skip-virtual --color-soldermask 0.1 0.1 0.1 --color-silk 0.95 0.95 0.95 --skip-raytrace transform z+ z+ + ./electronics/scripts/export_3d.py electronics/view_screen/view_screen.kicad_pcb --suffix front --width 1024 --height 1024 --skip-virtual transform z+ z+ rx+ rx+ rz- ry- ry- mu cp electronics/build/view_screen-front-3d.png electronics/build/outputs ./scripts/annotate_image.sh electronics/build/outputs/view_screen-front-3d.png - ./electronics/scripts/export_3d.py electronics/view_screen/view_screen.kicad_pcb --suffix back --width 1280 --height 1280 --skip-virtual --color-soldermask 0.1 0.1 0.1 --color-silk 0.95 0.95 0.95 --skip-raytrace transform z+ z+ ry+ ry+ ry+ ry+ ry+ ry+ ry+ ry+ ry+ ry+ ry+ ry+ ry+ ry+ ry+ ry+ ry+ ry+ + ./electronics/scripts/export_3d.py electronics/view_screen/view_screen.kicad_pcb --suffix back --width 1024 --height 1024 --skip-virtual transform z+ z+ ry+ ry+ ry+ ry+ ry+ ry+ ry+ ry+ ry+ ry+ ry+ ry+ ry+ ry+ ry+ ry+ ry+ ry+ rx+ rx+ rz- ry+ ry+ mu cp electronics/build/view_screen-back-3d.png electronics/build/outputs ./scripts/annotate_image.sh electronics/build/outputs/view_screen-back-3d.png env: diff --git a/electronics/scripts/export_3d.py b/electronics/scripts/export_3d.py index ed19e19..af5a105 100755 --- a/electronics/scripts/export_3d.py +++ b/electronics/scripts/export_3d.py @@ -137,7 +137,7 @@ def _pcbnew_export_3d(output_file, width, height, transforms): time.sleep(2) -def export_3d(filename, suffix, width, height, transforms, raytrace, virtual, color_soldermask, color_silk): +def export_3d(filename, suffix, width, height, transforms, raytrace, virtual, color_soldermask, color_silk, color_board): pcb_file = os.path.abspath(filename) output_dir = os.path.join(electronics_root, 'build') file_util.mkdir_p(output_dir) @@ -157,6 +157,9 @@ def export_3d(filename, suffix, width, height, transforms, raytrace, virtual, co 'SilkColor_Red': str(color_silk[0]), 'SilkColor_Green': str(color_silk[1]), 'SilkColor_Blue': str(color_silk[2]), + 'BoardBodyColor_Red': str(color_board[0]), + 'BoardBodyColor_Green': str(color_board[1]), + 'BoardBodyColor_Blue': str(color_board[2]), 'RenderEngine': '1' if raytrace else '0', 'ShowFootprints_Virtual': '1' if virtual else '0', 'Render_RAY_ProceduralTextures': '0', @@ -177,8 +180,9 @@ if __name__ == '__main__': parser.add_argument('--height', type=int, default=1440) parser.add_argument('--skip-raytrace', action='store_true') parser.add_argument('--skip-virtual', action='store_true', help='Don\'t render virtual footprints') - parser.add_argument('--color-soldermask', type=float, nargs=3, help='Soldermask color as 3 floats from 0-1', default=[0.1, 0.1, 0.1]) - parser.add_argument('--color-silk', type=float, nargs=3, help='Silkscreen color as 3 floats from 0-1', default=[0.9, 0.9, 0.9]) + parser.add_argument('--color-soldermask', type=float, nargs=3, help='Soldermask color as 3 floats from 0-1', default=[0, 0, 0]) + parser.add_argument('--color-silk', type=float, nargs=3, help='Silkscreen color as 3 floats from 0-1', default=[1, 1, 1]) + parser.add_argument('--color-board', type=float, nargs=3, help='PCB substrate color as 3 floats from 0-1', default=[0.764705882, 0.729411765, 0.607843137]) # Use subparsers to for an optional nargs="*" choices argument (workaround for https://bugs.python.org/issue9625) subparsers = parser.add_subparsers(dest='which') @@ -189,4 +193,4 @@ if __name__ == '__main__': transforms = args.transform if args.which == 'transform' else [] - export_3d(args.pcb, args.suffix, args.width, args.height, transforms, not args.skip_raytrace, not args.skip_virtual, args.color_soldermask, args.color_silk) + export_3d(args.pcb, args.suffix, args.width, args.height, transforms, not args.skip_raytrace, not args.skip_virtual, args.color_soldermask, args.color_silk, args.color_board)