DEFDIAGRAMHIERARCHICALCHART
Consente di definire un diagramma di tipo organigramma.
Un esempio è la rappresentazione grafica della strutturazione interna di un'azienda o di un gruppo di elementi.
La fonte dati del controllo è una collezione di tipo BC_VID_DGR_ORG.
Ogni modifica obbliga l'ambiente a rigenerare l'intera disposizione degli elementi. La rigenerazione non è pesante, ma può produrre un effetto grafico di lampeggio in presenza di molti elementi. Per questo motivo, in caso di modifiche massive, è necessario utilizzare la specifica '@SUSPENDEDVIDREFRESH.
Parametri
| Parametro | Definizione | I/O | Versione traduttore | SMP | |
|---|---|---|---|---|---|
| NOME | Intero | ||||
| RET | |||||
| POS | |||||
| DIM | |||||
| ID | Stringa | ||||
| COLLEZIONEDATI | Collezione di classi | ||||
| MODIFICABILE | Intero | ||||
| AZIONE | Azione | ||||
| VISUALIZZAZIONE | Enumerazione | ||||
| GRID | |||||
| STACK | |||||
| EXPANDER | |||||
| DOCK | |||||
| PERSONALIZZABILE | Intero | ||||
| LINKTO |
RET
Consente di definire le coordinate della cella del reticolo da associare al controllo, allo scopo di gestire gli spostamenti sulla videata.
POS
Consente di definire la posizione del controllo rispetto al contenitore.
DIM
Dimensione del controllo.
Consente di indicare l'altezza e la larghezza. Per entrambi è possibile specificare l'unità di misura.
DIM[Altezza [UnitàMisura], Larghezza [UnitàMisura]]
L'unità di misura può essere: 'C' per il posizionamento a caratteri e 'P' per il posizionamento in pixel. L'indicazione è opzionale, se omesso si assume 'C' come default.
ID
Consente di definire l'identificativo univoco del controllo.
Viene utilizzato dall'ambiente per gestire le personalizzazioni effettuate durante l'esecuzione del programma.
COLLEZIONEDATI
Consente di definire gli elementi da visualizzare.
MODIFICABILE
Consente di definire se il diagramma è modificabile.
Parametro con valori ammessi, si possono utilizzare i seguenti valori:
| Valore | Descrizione |
|---|---|
0 | No |
1 | Si |
AZIONE
Consente di definire la callback richiamata quando un'entità viene selezionata.
VISUALIZZAZIONE
Consente di definire la dimensione iniziale e il layout delle entità.
Parametro enumerato, può assumere i seguenti valori:
| Valore | Descrizione |
|---|---|
DIAGRAMMABASE | Il layout dell'oggetto grafico riguarderà solo i dati contenuto all'interno dell'oggetto BC_VID_DGR_ORG. |
DIAGRAMMADIDETTAGLIO | Il layout dell'oggetto grafico riguarderà i dati contenuto all'interno dell'oggetto BC_VID_DGR_ORG, e i suoi relativi dettagli contenuto all'interno della BC_VID_DGR_ORG_ELEM. |
GRID
Consente di definire l'attached property riferita ad un pannello grid.
STACK
Consente di definire l'attached property riferita ad un pannello stack.
EXPANDER
Consente di definire l'attached property riferita ad un pannello expander.
DOCK
Consente di indicare se il controllo deve occupare tutto lo spazio del DockPanel in verticale e/o in orizzontale.
PERSONALIZZABILE
Consente di definire se il controllo grafico è personalizzabile dall'utente in fase di runtime.
Parametro con valori ammessi, si possono utilizzare i seguenti valori:
| Valore | Descrizione |
|---|---|
0 | No |
1 | Si |
LINKTO
Consente di definire un legame tra due controlli esistenti all'interno della stessa videata.
Metodi
| Metodo | Descrizione | SMP |
|---|---|---|
| Copia_Su_Clipboard | Copia il diagramma in memoria | |
| Get_Elemento | Restituisce la classe riferita all'elemento selezionato | |
| Riposizionamento_Automatico | Riposiziona senza personalizzazioni tutti gli elementi del diagramma | |
| Salva_Immagine | Salvataggio del diagramma come immagine | |
| Set_Visualizzazione | Imposta il tipo di visualizzazione dell'organigramma | |
| Set_Zoom | Imposta un fattore di zoom | |
| Stampa | Stampa diagramma |
Esempi
Esempio DIAG
'@DEFVID DIM[35,140] NOME[Videata] ID["IDVIDEATA"] TIT["Titolo Videata"]
'@DEFGRIDPANEL NOME[GridPanel] ID["GridPanel"] _
RIGA[ALTEZZA[0.5] LAYOUT[#FISSO]] _
RIGA[ALTEZZA[34] LAYOUT[#FISSO]] _
RIGA[ALTEZZA[0.5] LAYOUT[#FISSO]] _
COLONNA[LUNGHEZZA[0.5] LAYOUT[#FISSO]] _
COLONNA[LUNGHEZZA[139] LAYOUT[#DINAMICO]] _
COLONNA[LUNGHEZZA[0.5] LAYOUT[#FISSO]]
'@DEFDIAGRAMHIERARCHICALCHART NOME[DIAG] ID["DIAG"] RET[1,1] POS[1,1] DIM[34,139] _
COLLEZIONEDATI[CollezioneDiagrammi] MODIFICABILE[0] _
GRID[COL[2] RIGA[2] COLDIN[1] RIGADIN[1]]
'@ENDGRIDPANEL NOME[GridPanel]
'@RUNVID
...
'@SRP Load()
InitDIAG()
Return
...
'@SRP InitDIAG()
Diagramma.Id="01"
Diagramma.Titolo="Direzione"
Diagramma.Sottotitolo="Presidente AD"
Diagramma.Dettaglio1="Mario Rossi"
Diagramma.IdPadre=""
CollezioneDiagrammi .AggiungiElemento(Diagramma [INOUT])
Diagramma.Id="02"
Diagramma.Titolo="Direzione Operativa"
Diagramma.Sottotitolo=""
Diagramma.Dettaglio1="Margherita Rosa"
Diagramma.IdPadre="01"
CollezioneDiagrammi.AggiungiElemento(Diagramma [INOUT])
Diagramma.Id="03"
Diagramma.Titolo="Direzione Sviluppo"
Diagramma.Sottotitolo="Direzione AD"
Diagramma.Dettaglio1="Giseppe Verdi"
Diagramma.IdPadre="01"
CollezioneDiagrammi.AggiungiElemento(Diagramma [INOUT])
Diagramma.Id="04"
Diagramma.Titolo="Direzione Tecnica"
Diagramma.Sottotitolo="Sviluppo Software"
Diagramma.Dettaglio1="Marco Giallo"
Diagramma.Dettaglio2="Architetturale"
Diagramma.IdPadre="01"
CollezioneDiagrammi.AggiungiElemento(Diagramma [INOUT])
Return