Delphi: Juster DBGrid-kolonnebredder automatisk

Designet for å gjøre det mulig for en bruker å se og redigere data i et tabellnett, the DBGrid gir forskjellige måter å tilpasse måten den representerer "dens" data på. Med så mye fleksibilitet, a Delphi utvikler kan alltid finne nye måter å gjøre det kraftigere.

En av de manglende funksjonene i TDBGrid er at det ikke er noe alternativ å automatisk justere bredden på spesifikke kolonner slik at de passer perfekt til nettets klientbredde. Når du endrer størrelse på DBGrid-komponenten under kjøretid, endres ikke størrelse på kolonnebredde.

Hvis bredden på DBGrid er større enn den totale bredden på alle kolonnene, får du et tomt område rett etter den siste kolonnen. På den annen side, hvis den totale bredden på alle kolonnene er større enn bredden på DBGrid, vil en horisontal rullefelt vises.

Juster DBGrid-kolonnebredder automatisk

Det er en praktisk prosedyre du kan følge som fikser bredden av selektive DBGrid-kolonner når rutenettet endres i løpet av driftstiden.

Det er viktig å merke seg at det vanligvis bare er to til tre kolonner i en DBGrid som faktisk må endres. alle de andre kolonnene viser data om "statisk bredde". For eksempel kan du alltid spesifisere fast bredde for kolonner som viser verdier fra datafelt som er representert med TDateTimeField, TFloatField, TIntegerField og lignende.

instagram viewer

Dessuten vil du sannsynligvis opprette (på designtidspunktet) vedvarende feltkomponenter ved hjelp av Fields-redigereren, for å spesifisere feltene i datasettet, deres egenskaper og deres bestilling. Med et TField-etterkommerobjekt kan du bruke Tag-egenskapen for å indikere at en bestemt kolonne som viser verdier for det feltet, må være automatisk størrelse.

Dette er ideen: Hvis du vil at en kolonne skal tilpasse den tilgjengelige plassen automatisk, tilordner du en heltallverdi for TField-etterkommerens Tag-egenskap som angir den tilsvarende kolonnens minimumsbredde.

FixDBGridColumnsWidth-prosedyren

Før du begynner, i OnCreate-arrangement for skjemaobjektet som inneholder DBGrid, spesifiser hvilke kolonner som må endres størrelse automatisk ved å tilordne en verdi som ikke er null for Tag-egenskapen til det tilsvarende TField-objektet.

fremgangsmåte TForm1.FormCreate (avsender: TObject);
begynne
// sette opp autoresizable kolonner ved å tilordne
// Minimm Bredde i Tag-egenskapen.

// ved bruk av fast verdi: 40 px
Table1.FieldByName ('FirstName'). Tag: = 40;
// bruker variabel verdi: bredden på
// standard kolonnen titteltekst
Tabell1.FieldByName ('LastName'). Tag: = 4 + lerret. TextWidth (Table1.FieldByName ('LastName'). DisplayName);
slutt
;

I koden ovenfor er Tabell 1 en TTable-komponent koblet til a DataSource-komponent, som er knyttet til DBGrid. Tabellen1.Tabellegenskaper peker til DBDemos-ansattstabellen.

Vi har merket kolonnene som viser verdiene for felt for fornavn og etternavn, slik at de kan endre størrelsen på automatisk. Neste trinn er å kalle FixDBGridColumnsWidth i OnResize-hendelseshåndtereren for skjemaet:

fremgangsmåte TForm1.FormResize (avsender: TObject);
begynne
FixDBGridColumnsWidth (DBGrid1);
slutt
;

Merk: Alt dette er fornuftig hvis Align-egenskapen til DBGrid inkluderer en av følgende verdier: alTop, alBottom, alClient eller alCustom.

Til slutt, her er FixDBGridColumnsWidth-prosedyrens kode:

fremgangsmåte FixDBGridColumnsWidth (konst DBGrid: TDBGrid);
Var
i: heltall; TotWidth: heltall; VarWidth: heltall; ResizableColumnCount: heltall; AColumn: TColumn;
begynne
// total bredde på alle kolonnene før størrelse
Totbredde: = 0;
// hvordan dele inn noen ekstra plass i nettet
Varvidde: = 0;
// hvor mange kolonner som må endres automatisk
ResizableColumnCount: = 0;
til i: = 0 til -1 + DBGrid. Kolonner. Telle dobegin
TotWidth: = TotWidth + DBGrid. Kolonner [i] .Width;
hvis DBGrid. Kolonner [i] .Field. Merk 0 deretter
Inc (ResizableColumnCount);
slutt;
// legg til 1 px for kolonneseparatorlinjenhvis dgColLines i DBGrid. alternativer deretter
TotWidth: = TotWidth + DBGrid. Kolonner. Telle;
// legg til indikatorens kolonnebreddehvis dgIndicator i DBGrid. alternativer deretter
TotWidth: = TotWidth + IndicatorWidth;
// bredde vale "venstre"
VarWidth: = DBGrid. ClientWidth - TotWidth;
// Distribuer VarWidth likt
// til alle kolonene som kan endre størrelsen på nytt
hvis ResizableColumnCount> 0 deretter
VarWidth: = varWidth div ResizableColumnCount;
til i: = 0 til -1 + DBGrid. Kolonner. Telle dobegin
AColumn: = DBGrid. Kolonner [i];
hvis AColumn. Felt. Merk 0 thenbegin
AColumn. Bredde: = AColumn. Bredde + VarBredde;
hvis AColumn. Bredde da
AColumn. Bredde: = AColumn. Felt. Stikkord;
slutt;
slutt;
slutt
; (* FixDBGridColumnsWidth *)