From 8942abfc640d594994b18927e11c9018c9c09716 Mon Sep 17 00:00:00 2001 From: Jeff Young Date: Mon, 29 May 2023 21:58:49 +0100 Subject: [PATCH] Handle through-hole via walls along with pads. Fixes https://gitlab.com/kicad/code/kicad/-/issues/14757 (cherry picked from commit cb7f314f4b564048f828bd961155d9e71b6f08ab) --- .../3d_rendering/opengl/create_scene.cpp | 31 +++++++++++++++++-- 1 file changed, 28 insertions(+), 3 deletions(-) diff --git a/3d-viewer/3d_rendering/opengl/create_scene.cpp b/3d-viewer/3d_rendering/opengl/create_scene.cpp index 8cb5ab6139..feced0f1f6 100644 --- a/3d-viewer/3d_rendering/opengl/create_scene.cpp +++ b/3d-viewer/3d_rendering/opengl/create_scene.cpp @@ -27,6 +27,7 @@ #include #include #include "../../3d_math.h" +#include "convert_basic_shapes_to_polygon.h" #include #include #include // To use GetRunningMicroSecs or another profiling utility @@ -775,6 +776,9 @@ void RENDER_3D_OPENGL::generateViasAndPads() { const PCB_VIA* via = static_cast( track ); + if( via->GetViaType() == VIATYPE::THROUGH ) + continue; // handle with pad holes so castellation is taken into account + const float holediameter = via->GetDrillValue() * m_boardAdapter.BiuTo3dUnits(); const int nrSegments = m_boardAdapter.GetCircleSegmentCount( via->GetDrillValue() ); const float hole_inner_radius = holediameter / 2.0f; @@ -804,14 +808,33 @@ void RENDER_3D_OPENGL::generateViasAndPads() } - if( m_boardAdapter.GetHoleCount() > 0 ) + if( m_boardAdapter.GetHoleCount() > 0 || m_boardAdapter.GetViaCount() > 0 ) { - SHAPE_POLY_SET tht_outer_holes_poly; // Stores the outer poly of the copper holes (the pad) - SHAPE_POLY_SET tht_inner_holes_poly; // Stores the inner poly of the copper holes (the hole) + SHAPE_POLY_SET tht_outer_holes_poly; // Stores the outer poly of the copper holes + SHAPE_POLY_SET tht_inner_holes_poly; // Stores the inner poly of the copper holes tht_outer_holes_poly.RemoveAllContours(); tht_inner_holes_poly.RemoveAllContours(); + // Insert through-via holes (vertical cylinders) + for( const PCB_TRACK* track : m_boardAdapter.GetBoard()->Tracks() ) + { + if( track->Type() == PCB_VIA_T ) + { + const PCB_VIA* via = static_cast( track ); + + if( via->GetViaType() == VIATYPE::THROUGH ) + { + TransformCircleToPolygon( tht_outer_holes_poly, via->GetPosition(), + via->GetDrill() / 2 + platingThickness, + ARC_HIGH_DEF, ERROR_INSIDE ); + + TransformCircleToPolygon( tht_inner_holes_poly, via->GetPosition(), + via->GetDrill() / 2, ARC_HIGH_DEF, ERROR_INSIDE ); + } + } + } + // Insert pads holes (vertical cylinders) for( const FOOTPRINT* footprint : m_boardAdapter.GetBoard()->Footprints() ) { @@ -903,7 +926,9 @@ void RENDER_3D_OPENGL::Load3dModelsIfNeeded() load3dModels( &activityReporter ); } else + { load3dModels( nullptr ); + } }