68 lines
2.5 KiB
Markdown
68 lines
2.5 KiB
Markdown
# Print Calculator (OrcaSlicer Edition)
|
|
|
|
Un'applicazione Full Stack (Angular + Spring Boot) per calcolare preventivi di stampa 3D precisi utilizzando **OrcaSlicer** in modalità headless.
|
|
|
|
## Funzionalità
|
|
|
|
* **Slicing Reale**: Usa il motore di OrcaSlicer per stimare tempo e materiale, garantendo la massima precisione.
|
|
* **Preventivazione Database-Driven**: Calcolo basato su politiche di prezzo configurabili nel database (costo materiale, ammortamento macchina a scaglioni, energia e markup).
|
|
* **Visualizzazione 3D**: Anteprima del file STL caricato tramite Three.js.
|
|
* **Multi-Profilo**: Supporto per diverse stampanti, materiali e profili di processo.
|
|
|
|
## Stack Tecnologico
|
|
|
|
- **Backend**: Java 21, Spring Boot 3.4, PostgreSQL, Flyway.
|
|
- **Frontend**: Angular 19, Angular Material, Three.js.
|
|
- **Slicer**: OrcaSlicer (invocato via CLI).
|
|
|
|
## Prerequisiti
|
|
|
|
* **Java 21** installato.
|
|
* **Node.js 22** e **npm** installati.
|
|
* **PostgreSQL** attivo.
|
|
* **OrcaSlicer** installato sul sistema.
|
|
|
|
## Avvio Rapido
|
|
|
|
### 1. Database
|
|
Crea un database PostgreSQL chiamato `printcalc`. Le tabelle verranno create automaticamente al primo avvio tramite Flyway.
|
|
|
|
### 2. Backend
|
|
Configura il percorso di OrcaSlicer in `backend/src/main/resources/application.properties` o tramite la variabile d'ambiente `SLICER_PATH`.
|
|
|
|
```bash
|
|
cd backend
|
|
./gradlew bootRun
|
|
```
|
|
|
|
### 3. Frontend
|
|
```bash
|
|
cd frontend
|
|
npm install
|
|
npm start
|
|
```
|
|
|
|
Accedi a [http://localhost:4200](http://localhost:4200).
|
|
|
|
## Configurazione Prezzi
|
|
|
|
I prezzi non sono più gestiti tramite variabili d'ambiente fisse ma tramite tabelle nel database:
|
|
- `pricing_policy`: Definisce markup, fee fissi e costi elettrici.
|
|
- `pricing_policy_machine_hour_tier`: Definisce i costi orari delle macchine in base alla durata della stampa.
|
|
- `printer_machine`: Anagrafica stampanti e consumi energetici.
|
|
- `filament_material_type` / `filament_variant`: Listino prezzi materiali.
|
|
|
|
## Struttura del Progetto
|
|
|
|
* `/backend`: API Spring Boot.
|
|
* `/frontend`: Applicazione Angular.
|
|
* `/backend/profiles`: Contiene i file di configurazione per OrcaSlicer.
|
|
|
|
## Troubleshooting
|
|
|
|
### Percorso OrcaSlicer
|
|
Assicurati che `slicer.path` punti al binario corretto. Su macOS è solitamente `/Applications/OrcaSlicer.app/Contents/MacOS/OrcaSlicer`. Su Linux è il percorso all'AppImage (estratta o meno).
|
|
|
|
### Database connection
|
|
Verifica le credenziali in `application.properties`. Se usi Docker, puoi passare `DB_URL`, `DB_USERNAME` e `DB_PASSWORD` come variabili d'ambiente.
|