home / skills / wedsamuel1230 / arduino-skills / enclosure-designer

enclosure-designer skill

/skills/enclosure-designer

This skill helps you quickly design 3D-printable enclosures for Arduino and ESP32 projects with parametric OpenSCAD templates and print guidance.

npx playbooks add skill wedsamuel1230/arduino-skills --skill enclosure-designer

Review the files below or copy the command above to add this skill to your agents.

Files (4)
SKILL.md
12.5 KB
---
name: enclosure-designer
description: Guides design and generation of 3D-printable enclosures for Arduino/ESP32/RP2040 projects. Use when user needs a case, box, housing, or enclosure for their electronics project. Provides parametric design guidance, OpenSCAD templates, STL generation tips, and print settings.
---

# Enclosure Designer

Creates 3D-printable enclosures for electronics projects.

## Resources

This skill includes bundled tools and templates:

- **scripts/generate_enclosure.py** - Parametric OpenSCAD generator with PCB database
- **assets/basic-template.scad** - Customizable OpenSCAD template

## Quick Start

**Generate for specific PCB:**
```bash
uv run --no-project scripts/generate_enclosure.py --pcb "Arduino Uno" --output uno_case.scad
uv run --no-project scripts/generate_enclosure.py --pcb "ESP32 DevKit" --output esp32_case.scad
```

**Custom dimensions:**
```bash
uv run --no-project scripts/generate_enclosure.py --width 100 --depth 60 --height 30 --output custom.scad
```

**Interactive mode:**
```bash
uv run --no-project scripts/generate_enclosure.py --interactive
```

**List supported PCBs:**
```bash
uv run --no-project scripts/generate_enclosure.py --list
```

## When to Use
- "I need a case for my project"
- "How do I make an enclosure?"
- "Design a box for my Arduino"
- User has working circuit, needs housing
- Preparing for deployment/presentation

## Design Workflow

### Step 1: Gather Measurements

Ask user for:
```
1. Main board dimensions (L × W × H in mm)
2. Component clearances (tallest component height)
3. Connectors/ports that need access (USB, power jack, etc.)
4. Mounting holes (positions, diameters)
5. Any displays, buttons, LEDs that need cutouts
6. Environment (indoor/outdoor, waterproof?)
```

### Step 2: Design Parameters

```
Enclosure Type: [Box/Clamshell/Snap-fit/Screw-mount]
Material: [PLA/PETG/ABS]
Wall Thickness: [2-3mm typical]
Mounting Style: [Standoffs/Clips/Rails]
Ventilation: [None/Slots/Holes]
Access: [Top-remove/Front-panel/Side-openings]
```

### Step 3: Generate Design

Choose approach:
1. **Parametric OpenSCAD** - Full customization
2. **Pre-made generator** - Quick results
3. **Manual Fusion360/TinkerCAD** - Visual design

---

## Parametric OpenSCAD Template

### Basic Project Box

```openscad
// === PARAMETRIC PROJECT BOX ===
// Customize these values for your project

// Internal dimensions (mm)
inner_length = 70;    // X axis
inner_width = 50;     // Y axis  
inner_height = 30;    // Z axis (internal depth)

// Wall and tolerances
wall = 2.5;           // Wall thickness
lid_tolerance = 0.4;  // Gap for lid fit
corner_radius = 3;    // Rounded corners

// Mounting standoffs
standoff_height = 5;  // PCB clearance from bottom
standoff_dia = 6;     // Standoff outer diameter
screw_hole_dia = 2.5; // M2.5 screw hole

// PCB mounting hole positions (from corner)
// Measure from your board!
pcb_holes = [
    [5, 5],           // Bottom-left
    [65, 5],          // Bottom-right
    [5, 45],          // Top-left
    [65, 45]          // Top-right
];

// Lid attachment
lid_screw_dia = 3;    // M3 screws
lid_screw_positions = [
    [5, 5],
    [inner_length-5, 5],
    [5, inner_width-5],
    [inner_length-5, inner_width-5]
];

// Cutouts (add as needed)
usb_cutout = true;
usb_x = 35;           // Center position
usb_width = 12;
usb_height = 8;

// === MODULES ===

module rounded_box(l, w, h, r) {
    hull() {
        for (x = [r, l-r])
            for (y = [r, w-r])
                translate([x, y, 0])
                    cylinder(h=h, r=r, $fn=32);
    }
}

module standoff(h, outer_d, inner_d) {
    difference() {
        cylinder(h=h, d=outer_d, $fn=24);
        cylinder(h=h+1, d=inner_d, $fn=24);
    }
}

module box_base() {
    outer_l = inner_length + 2*wall;
    outer_w = inner_width + 2*wall;
    outer_h = inner_height + wall;  // Bottom wall
    
    difference() {
        // Outer shell
        rounded_box(outer_l, outer_w, outer_h, corner_radius);
        
        // Inner cavity
        translate([wall, wall, wall])
            rounded_box(inner_length, inner_width, inner_height+1, corner_radius-wall);
        
        // USB cutout
        if (usb_cutout) {
            translate([wall + usb_x - usb_width/2, -1, wall + standoff_height])
                cube([usb_width, wall+2, usb_height]);
        }
    }
    
    // Add standoffs
    for (pos = pcb_holes) {
        translate([wall + pos[0], wall + pos[1], wall])
            standoff(standoff_height, standoff_dia, screw_hole_dia);
    }
}

module box_lid() {
    lid_wall = wall - lid_tolerance;
    outer_l = inner_length + 2*wall;
    outer_w = inner_width + 2*wall;
    lip_h = 5;  // How deep lid inserts
    
    // Lid top
    rounded_box(outer_l, outer_w, wall, corner_radius);
    
    // Lid lip (inserts into box)
    translate([wall + lid_tolerance, wall + lid_tolerance, -lip_h])
        difference() {
            rounded_box(inner_length - 2*lid_tolerance, 
                       inner_width - 2*lid_tolerance, 
                       lip_h, corner_radius - wall);
        }
}

// === RENDER ===

// Uncomment one at a time for printing:
box_base();
// translate([0, inner_width + 20, 0]) box_lid();
```

### Adding Cutouts

```openscad
// === CUTOUT LIBRARY ===

// Round hole (for buttons, LEDs)
module round_cutout(x, y, z, diameter, depth) {
    translate([x, y, z])
        rotate([90, 0, 0])
            cylinder(h=depth, d=diameter, $fn=32);
}

// Rectangle (for displays, SD cards)
module rect_cutout(x, y, z, width, height, depth) {
    translate([x - width/2, -0.1, z])
        cube([width, depth + 0.2, height]);
}

// Slot (for ventilation, cables)
module slot_cutout(x, y, z, width, height, depth) {
    translate([x, y, z])
        hull() {
            translate([0, 0, 0])
                cylinder(h=depth, d=height, $fn=24);
            translate([width-height, 0, 0])
                cylinder(h=depth, d=height, $fn=24);
        }
}

// OLED display cutout (128x64 module)
module oled_cutout() {
    // Visible area
    rect_cutout(inner_length/2, wall, inner_height - 15, 26, 14, wall+1);
    // Mounting holes (if needed)
}

// Common connector dimensions
usb_micro = [8, 3];      // USB Micro
usb_c = [9, 3.5];        // USB-C
barrel_jack = [12, 12];  // 5.5mm DC jack (round)
sd_card = [15, 3];       // SD card slot
```

---

## Online Generators (No CAD Needed)

### Ultimate Box Maker (Thingiverse)
https://www.thingiverse.com/thing:1264391

Parameters:
- Enter internal dimensions
- Choose wall thickness
- Select lid type (snap/screw/slide)
- Add ventilation slots
- Download STL

### Parametric Box by Heartman
https://www.thingiverse.com/thing:1355018

Good for:
- Simple project boxes
- Snap-fit lids
- Basic customization

### FreeCAD + Parametric Enclosure
1. Install FreeCAD
2. Use Spreadsheet workbench for parameters
3. Generate enclosure with formulas
4. Export STL

---

## Common Board Dimensions

### Arduino Family
| Board | L × W × H (mm) | Mounting Holes |
|-------|----------------|----------------|
| UNO R3 | 68.6 × 53.4 × 15 | 4 holes, 3.2mm |
| Nano | 45 × 18 × 8 | 2 holes, 1.5mm |
| Mega 2560 | 101.5 × 53.4 × 15 | 4 holes, 3.2mm |
| Pro Mini | 33 × 18 × 5 | None standard |

### ESP32 Family
| Board | L × W × H (mm) | Mounting Holes |
|-------|----------------|----------------|
| DevKit V1 (38pin) | 55 × 28 × 10 | None (use clips) |
| DevKit V1 (30pin) | 49 × 26 × 10 | None |
| NodeMCU-32S | 51 × 25 × 10 | 2 holes, 3mm |
| ESP32-CAM | 40 × 27 × 12 | 2 holes, 2mm |

### Raspberry Pi Pico
| Board | L × W × H (mm) | Mounting Holes |
|-------|----------------|----------------|
| Pico/Pico W | 51 × 21 × 4 | 4 holes, 2.1mm |

### Common Modules
| Module | L × W × H (mm) | Notes |
|--------|----------------|-------|
| SSD1306 OLED 0.96" | 27 × 27 × 4 | 4 corners 2mm |
| BME280 | 15 × 12 × 3 | 2 holes 2mm |
| SD Card | 42 × 24 × 5 | 4 corners 2mm |
| TP4056 | 26 × 17 × 4 | None |
| 18650 holder | 77 × 21 × 19 | Varies |

---

## Design Guidelines

### Wall Thickness
```
Application              Thickness
─────────────────────────────────────
Desktop/indoor           2.0 mm
Portable/handheld        2.5 mm
Outdoor                  3.0 mm
Structural/load-bearing  4.0+ mm
```

### Clearances
```
Component           Add clearance
─────────────────────────────────────
PCB to wall         1-2 mm
USB/connector       0.5 mm extra per side
Moving parts        2-3 mm
Lid fit             0.3-0.5 mm gap
```

### Mounting Strategies

**PCB Standoffs:**
```
    [Standoff]──┐
        │       │
    [PCB]       │ standoff_height
        │       │
    ────────────┘
        ▲
     box_floor
```

**Edge Rails:**
```
    ┌────────────┐
    │    [PCB]   │
    │  ───────   │
    │ /       \  │  <-- Rails support PCB edges
    └───┘   └────┘
```

**Snap-in Clips:**
```
    ┌──╲   ╱──┐
    │   [PCB] │
    │  ───────│
    └─────────┘
        ▲
     Flexible clips
```

### Ventilation

**When needed:**
- MCU draws >100mA continuously
- Motor drivers
- Power regulators
- Any component getting warm

**Vent patterns:**
```
// Slot pattern (easy to print, good flow)
for (i = [0:5]) {
    translate([10 + i*8, wall/2, 10])
        slot_cutout(20, 3, wall+1);
}

// Honeycomb (looks cool, harder to print)
// Use pre-made pattern from Thingiverse
```

---

## Print Settings

### Material Selection

| Material | Pros | Cons | Best For |
|----------|------|------|----------|
| **PLA** | Easy to print, cheap | Weak to heat (>50°C) | Indoor projects |
| **PETG** | Heat resistant, strong | Stringing, harder | Outdoor, functional |
| **ABS** | Heat resistant, tough | Warps, fumes | Professional |
| **ASA** | UV resistant | Like ABS | Outdoor long-term |

### Recommended Settings

**PLA Enclosure:**
```
Layer height: 0.2mm
Wall count: 3-4 (for 2-3mm wall)
Infill: 15-20%
Support: Usually not needed if designed right
Bed temp: 60°C
Nozzle temp: 200-210°C
```

**PETG Enclosure:**
```
Layer height: 0.2mm
Wall count: 3-4
Infill: 20-25%
Support: Often needed
Bed temp: 80°C
Nozzle temp: 230-245°C
Print slower than PLA
```

### Orientation Tips

```
Print box BASE standing up (opening facing up)
- No supports needed
- Good surface finish inside
- Strong walls

Print LID flat (top surface down)
- Smooth exterior surface
- May need supports for cutouts
```

---

## Waterproofing

### IP Rating Guide
```
IP65 - Dust tight, water jets OK
IP67 - Dust tight, submersible briefly
IP68 - Dust tight, continuous submersion
```

### Strategies

**Rubber Gasket:**
```
Add groove in lid for O-ring:
    ┌───╔═══════╗───┐
    │   ║O-ring ║   │
    │   ╚═══════╝   │
    │    [box]      │
    └───────────────┘
```

**Cable Glands:**
- Use PG7/PG9 cable glands for wires
- Drill precise holes, thread in glands
- Seal with silicone if needed

**Conformal Coating:**
- Spray PCB with conformal coat
- Protects electronics inside box

---

## Example: ESP32 Weather Station Enclosure

```openscad
// ESP32 Weather Station Enclosure
// Components: ESP32 DevKit, BME280, SSD1306 OLED, 18650 battery

// Internal dimensions (measured from components + clearance)
inner_length = 80;
inner_width = 55;
inner_height = 50;  // Room for battery under PCB

wall = 3;  // Outdoor = thicker walls

// ESP32 on standoffs
esp_standoff_h = 25;  // Above battery
esp_holes = [[5, 5], [5, 50], [52, 5], [52, 50]];

// OLED window position (top of enclosure)
oled_x = 40;
oled_y = 15;
oled_w = 28;
oled_h = 16;

// BME280 vent hole
bme_vent_x = 70;
bme_vent_y = 30;
bme_vent_dia = 8;

// USB access
usb_x = 30;
usb_y = inner_height - 15;

// Generate with above parameters...
```

---

## Troubleshooting

| Problem | Cause | Solution |
|---------|-------|----------|
| Lid too tight | Tolerance too small | Increase to 0.5mm |
| Lid too loose | Tolerance too large | Decrease, add clips |
| Screws strip | Holes too large | Use proper thread inserts |
| Parts don't fit | Measurement error | Remeasure, print test piece |
| Weak walls | Too thin, low infill | Increase wall count |
| Warping | ABS, big flat surfaces | Use brim, enclosure, PETG |

---

## Resources

- **OpenSCAD**: https://openscad.org
- **Thingiverse Customizer**: Parametric designs
- **Printables**: More enclosure designs
- **McMaster-Carr**: Reference for hardware dimensions

Overview

This skill guides the design and generation of 3D-printable enclosures for Arduino, ESP32, and RP2040 projects. It provides parametric design guidance, ready OpenSCAD templates, and practical printing and material advice. The goal is a fast, reliable workflow from measurements to printable SCAD/STL output.

How this skill works

You provide board dimensions, component heights, connector positions and required cutouts. The skill uses parametric OpenSCAD templates to generate a base, lid, standoffs and cutouts, or it can produce custom dimensions and interactive prompts. It also offers printing orientation, material recommendations and troubleshooting tips for fitting, tolerances and waterproofing.

When to use it

  • You have a working circuit and need a protective case for deployment or presentation
  • You need a quick parametric SCAD/STL for a specific PCB like Arduino, ESP32, or Pico
  • You want guidance on cutouts, standoffs, or mounting hole placement
  • You need material and print settings for indoor, outdoor or battery-powered projects
  • You want tips for lid fits, snap‑fits, or waterproofing with gaskets

Best practices

  • Start by measuring board L×W×H, tallest components and connector offsets before designing
  • Use 2–3 mm walls for desktop/indoor and 3+ mm for outdoor or structural parts
  • Include 0.3–0.5 mm lid tolerance and 1–2 mm clearance from PCB to walls
  • Print the base standing with opening facing up and the lid flat for best finish
  • Prototype critical cutouts and standoffs at 0.5× scale to validate fit before full print

Example use cases

  • Generate an ESP32 DevKit weather station enclosure with standoffs, OLED window and BME280 vent
  • Create a custom box for an Arduino Uno with USB and barrel jack cutouts and screw-mounted lid
  • Design a battery-backed RP2040 handheld with 18650 compartment and access door
  • Quickly produce a snap-fit project box using parametric OpenSCAD for a prototype
  • Add an O-ring groove and cable glands for an IP65 splash-resistant outdoor sensor box

FAQ

Which material should I choose for outdoor enclosures?

Use PETG for good heat and weather resistance or ASA for UV stability; increase wall thickness to 3–4 mm.

How do I avoid a lid that is too tight or too loose?

Start with a 0.3–0.5 mm tolerance for the lid lip, print a small test section, then adjust. Consider clips or screws if tolerance control is difficult.