Entra

View Full Version : [JAVA] Importare ed utilizzare DXF/DWG


franksisca
03-06-2011, 19:22
Salve a tutti.

conoscete librerie o qualcosa di simile per un file DXF/DWG e il disegno al suo interno per lavorare con i dati???

esempio banale, se volessi calcorale l'area di un quadrato disegnato in Autocad (e quindi salvato in dxf) nel mio software in java, come dovrei fare?

se non conoscete nulla, sapreste indirizzarmi?

banryu79
06-06-2011, 09:38
Salve a tutti.

conoscete librerie o qualcosa di simile per un file DXF/DWG e il disegno al suo interno per lavorare con i dati???

Ciao, se ti basta supportare il formato DXF, per Java cerca la libreria chiamata Kabeja (http://kabeja.sourceforge.net/). L'ho usata e fa il suo sporco lavoro.


esempio banale, se volessi calcorale l'area di un quadrato disegnato in Autocad (e quindi salvato in dxf) nel mio software in java, come dovrei fare?

Con Kabeja, apri il file dxf, lo fai parsare al parser che mette a disposizione (consulta la documentazione) e a quel punto hai un oggetto tipo DOM che puoi interrogare (contiene tutte le entità e la struttra [i layer] che il parser ha letto nel file dxf)

Se il tuo disegno in dxf contiene solo il quadrato, il quale è stato disegnato con 4 entità linea, ad esempio, chiederai al Document tutte le entità linea, per poi farci quello che vuoi. Se invece è una polilyne, chiederai quella.
Avendo le 4 linee del tuo quadrato (ma se è proprio un quadrato ovviamente ne basta anche solo una) calcolarne l'area è molto semplice.

Se invece hai più "forme" nel disegno e il tuo software deve prima capire/individuare quali/come sono quelle interessanti o cumunque deve distinguerle una ad una, la faccenda si complica. In linea di massima il passo base (almeno per la mia esperienza) è prendere tutte le entità e costrutire un grafo non orientato dove i punti dxf sono i nodi del grafo e le entità dxf che uniscono due punti assieme (linee, archi di cerchio...) sono gli archi del grafo: i singoli componenti connessi del grafo sono le singole "forme".

Avendo così individuato i singoli componenti connessi, è poi possibile analizzarli in diversi modi (usando le proprità dei grafi) per ricavare diverse informazioni su di essi (la forma è chiusa o aperta, che tipo di "percorso" descrive, se è auto-intersecante o meno, ecc...)

Ma queste considerazioni dipendono dal tipo di problema che ti appresti a risolvere.

franksisca
06-06-2011, 12:40
la mia idea era calcolare l'area di un appartamento....quindi si prospetta un lavoraccio...right?

banryu79
06-06-2011, 12:56
la mia idea era calcolare l'area di un appartamento....quindi si prospetta un lavoraccio...right?
Beh, non è certo una cosa banale, ma neanche un'impresa monumentale... almeno credo :D

Immagino a te serva dunque identificare tutti i muri della pianta dell'appartamento, tanto per cominciare.

Molto dipende da come ti "arrivano i dati": se si può fare l'assunzione che i muri, e solo i muri, sono isolati su un certo layer, importi il dxf sottoforma di DOM Kabeja, e chiedi tutte le entità di quel layer: hai in mano tutto.

A partire da quei dati devi poi sviluppare il tuo algoritmo per analizzarli (ad esempio ricavare il perimetro dei singoli poligoni che rappresentano le varie aree definite dalle stanze dell'appartamento) e ricavarti l'area (che può anche essere una cosa molto banale, ad esempio applicando il teorema di Green [link] (http://mathworld.wolfram.com/Area.html))

Se invece non puoi fare un'assunzione del tipo descritto prima, allora la faccenda si complica smisuratamente (devi implementare un algoritmo per riconoscere un'insieme di entità come descrivente "un muro" e non altri oggetti presenti in pianta... auguri)

A meno che la tua applicazione non preveda un'interazione con l'utente: prendi il DOM Kabeja del dxf, lo importi/rappresenti con tue entità che renderizzi a video; l'utente interagisce con la tua rappresentazione dell'appartamento per isolare/identificare lui i muri.
Questo non è impossibile ma è certamente molto molto più laborioso (leggi: si prospetta "il lavoraccio")


@EDIT:
P.S.: Ah, dimenticavo: Kabeja non è solo un'importatore; mette a disposizione una toolchain per partire da input dxf e arrivare a produrre diversi output (ad esempio in formato SVG), eventualmente dopo aver filtrato i dati. Potrebbe essere utile per la rappresentazione a video (probabilmente meno utile se l'utente deve anche manipolarli, ma cito la cosa perchè so per sentito dire che il formato SVG è utilizzato in Batik e che Batik fornisce un componente Swing out-of-the-box. A tirare nel carretto anche questi strumenti diventa quindi possibile e penso anche relativamente poco complesso arrivare a una rappresentazione a video anche di piantine molto articolate... non saprei però circa l'interazione utente-UI per quanto riguarda l'aver a che fare con il formato SVG, che non conosco).

franksisca
06-06-2011, 15:42
Beh, non è certo una cosa banale, ma neanche un'impresa monumentale... almeno credo :D

Immagino a te serva dunque identificare tutti i muri della pianta dell'appartamento, tanto per cominciare.

Molto dipende da come ti "arrivano i dati": se si può fare l'assunzione che i muri, e solo i muri, sono isolati su un certo layer, importi il dxf sottoforma di DOM Kabeja, e chiedi tutte le entità di quel layer: hai in mano tutto.

A partire da quei dati devi poi sviluppare il tuo algoritmo per analizzarli (ad esempio ricavare il perimetro dei singoli poligoni che rappresentano le varie aree definite dalle stanze dell'appartamento) e ricavarti l'area (che può anche essere una cosa molto banale, ad esempio applicando il teorema di Green [link] (http://mathworld.wolfram.com/Area.html))

Se invece non puoi fare un'assunzione del tipo descritto prima, allora la faccenda si complica smisuratamente (devi implementare un algoritmo per riconoscere un'insieme di entità come descrivente "un muro" e non altri oggetti presenti in pianta... auguri)

A meno che la tua applicazione non preveda un'interazione con l'utente: prendi il DOM Kabeja del dxf, lo importi/rappresenti con tue entità che renderizzi a video; l'utente interagisce con la tua rappresentazione dell'appartamento per isolare/identificare lui i muri.
Questo non è impossibile ma è certamente molto molto più laborioso (leggi: si prospetta "il lavoraccio")


@EDIT:
P.S.: Ah, dimenticavo: Kabeja non è solo un'importatore; mette a disposizione una toolchain per partire da input dxf e arrivare a produrre diversi output (ad esempio in formato SVG), eventualmente dopo aver filtrato i dati. Potrebbe essere utile per la rappresentazione a video (probabilmente meno utile se l'utente deve anche manipolarli, ma cito la cosa perchè so per sentito dire che il formato SVG è utilizzato in Batik e che Batik fornisce un componente Swing out-of-the-box. A tirare nel carretto anche questi strumenti diventa quindi possibile e penso anche relativamente poco complesso arrivare a una rappresentazione a video anche di piantine molto articolate... non saprei però circa l'interazione utente-UI per quanto riguarda l'aver a che fare con il formato SVG, che non conosco).

grazie per le info...vedrò cosa si può fare.