Delphi-PRAXiS
Seite 1 von 3  1 23      

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   Delphi Grid mit gruppierter Darstellung (https://www.delphipraxis.net/143937-grid-mit-gruppierter-darstellung.html)

NetSonic 26. Nov 2009 11:28

Datenbank: PostgreSQL • Version: 8.3 • Zugriff über: ZeosLib

Grid mit gruppierter Darstellung
 
Hallo liebe Delphi-Kollegen,

mir fehlt vielleicht auch einfach nur die richtige Formulierung um bei der Forensuche das richtige Ergebnis zu bekommen oder ich habs überlesen - jedenfalls möchte ich folgendes realisieren:

Ich hole mir aus zwei Tabellen meiner Datenbank Ergebnismengen. Beide Tabellen miteinander Verknüpft.
Aus Tabelle A hole ich mir Name und ID. Aus Tabelle B Länge, Breite, Höhe etc. mit Bezug auf die ID aus Tabelle A. Das ganze möchte ich dann "gruppiert" in einer DBGrid oder eben einer entsprechenden Komponente wie folgt dargestellt haben:

Delphi-Quellcode:
+ "Testobjekt A"
  - Länge           - Breite          - Höhe
  - Länge           - Breite          - Höhe
+ "Testobjekt B"
  - Länge           - Breite          - Höhe
+ "Testobjekt C"
  - Länge           - Breite          - Höhe
  - Länge           - Breite          - Höhe
  - Länge           - Breite          - Höhe
Wie kann man solch eine Darstellung am einfachsten umsetzen?

hoika 26. Nov 2009 11:42

Re: Grid mit gruppierter Darstellung
 
Hallo,

DBGrid
Dann musst du dir den SQL-Befehl schon so zusammenbauen
-> Case, Stored Procedure

DBGrid / TClientDataSet
Dort könnte man eine Tabelle so anlegen,
wie sie im DBGrid angezeigt wird
Die füllst du dann "per Hand"

StringGrid
Hier kannst du das Einfügen selber machen
Ich mache bei den Gruppen immer

Name-Spalte
[Gruppe1]
Inhalt 1
Inhalt 2
// Leerzeile
[Gruppe2]


Heiko

KrasserChecker 26. Nov 2009 11:51

Re: Grid mit gruppierter Darstellung
 
Wenn's Geld kosten darf:
ExpressQuantumGrid Suite von Developer Express.
siehe Screenshot ganz unten auf der Seite

NetSonic 26. Nov 2009 12:00

Re: Grid mit gruppierter Darstellung
 
Zitat:

Zitat von KrasserChecker
Wenn's Geld kosten darf:
ExpressQuantumGrid Suite von Developer Express.
siehe Screenshot ganz unten auf der Seite

So wie auf dem Screenshot wäre natürlich traumhaft aber kann man das auch mit freien Komponenten realisieren? Geht sowas ner VirtualStringGrid??? Habe damit noch nie gearbeitet...

Mike_on_Tour 26. Nov 2009 12:37

Re: Grid mit gruppierter Darstellung
 
Hallo,

eine freie Komponente ist z.B. das SMDBGrid (SMDBGrid von Scalabium). Die Gruppierung von Daten ist zwar nicht groß dokumentiert, aber es funktioniert mit kleinen Tricks. Ich habe gerade mal einen kleinen Test gemacht, da ich die Gruppierung auch noch einsetzen will.

Mike

chaosben 26. Nov 2009 13:31

Re: Grid mit gruppierter Darstellung
 
Zitat:

Zitat von NetSonic
Geht sowas ner VirtualStringGrid???

Ganz nah dran. :) Ein VirtualStringTree macht das für lau.
Das fällt zwar nicht in die Kategorie "am einfachsten" bietet aber fast alle Möglichkeiten

NetSonic 26. Nov 2009 13:50

Re: Grid mit gruppierter Darstellung
 
OK, danke für die Tipps. Ich werde mich mal damit auseinandersetzen und mich ggf. wieder melden, wenn ich Probleme habe... :zwinker:

NetSonic

hoika 26. Nov 2009 13:59

Re: Grid mit gruppierter Darstellung
 
Hall0,

Zitat:

Ganz nah dran. Smile Ein VirtualStringTree macht das für lau.
Beweise, Screenshots ...
Und bitte nicht auf die Galerie verweisen.

Oder meinst du die TreeView/ListView Kombination,
das wäre in der Tat sowas wie Grouping.


Heiko

NetSonic 26. Nov 2009 14:15

Re: Grid mit gruppierter Darstellung
 
@Mike: Kannst Du mir das kurz Hilfestellung zwecks Gruppierung geben? Ich habe die Komponente bereits installiert und auch in mein Programm eingebunden. Die "normalen" Daten werden auch angezeigt. Aber wo muss ich jetzt ansetzen??? Ich habe zwar die Eigenschaft "Grouping" gefunden, aber was muss ich dann im Feld "Expression" eingeben??? :gruebel:

NetSonic

Mike_on_Tour 26. Nov 2009 14:45

Re: Grid mit gruppierter Darstellung
 
Zitat:

Zitat von NetSonic
@Mike: Kannst Du mir das kurz Hilfestellung zwecks Gruppierung geben? ... Ich habe zwar die Eigenschaft "Grouping" gefunden, aber was muss ich dann im Feld "Expression" eingeben??? :gruebel:
NetSonic

OK, ich versuchs mal.

Du hast ja sicher eine Query-Komponente. Dort mußt Du die SELECT-Anweisung so erweitern:
SQL-Code:
SELECT *, 2 as flag
FROM tabelle
WHERE (bedingung)

UNION ALL

SELECT DISTINCT *, 1 as flag
FROM tabelle
WHERE (bedingung)

ORDER BY feldname, flag
Zur Erklärung: Du mußt die SQL-Anweisung mit einer 'UNION' "verdoppeln". Dabei darf das zweite SELECT nur einen Datensatz pro Gruppe ergeben, deshalb das 'DISTINCT' unbedingt angeben. In jedem SELECT muß noch ein Kennzeichen angegeben werden (ich habe das als 'flag' bezeichnet). Alle Gruppenzeilen bekommen als 'flag' den Wert 1 und alle Datenzeilen zur Gruppe den Wert 2. Mit ORDER BY läßt sich das dann noch sortieren.

Dann legt Du in der Eigenschaft 'Grouping' einen Eintrag an und trägst bei Expression 'flag' ein.
Für das Event 'OnExpression' trägst Du folgenden Code ein:
Delphi-Quellcode:
if (Query1.FieldByName(Expression).AsInteger = 1)
  then begin
    Value := True;
    Text := 'Gruppenüberschrift: ' + Query1.FieldByName('feldname').AsString;
  end;
Zur Erklärung: Im Parameter 'Expression' wird der Eintrag aus der Grouping-Eigenschaft übergeben (automatisch). Im Parameter 'Text' übergibst Du einfach das, was in der Gruppenzeile stehen soll.

Die Ausgabe der Gruppenzeile kannst bzw. mußt Du im Event 'OnDrawGroupingCell' steuern:
Delphi-Quellcode:
DefaultDrawing := False;

ACanvas.Brush.Color := Group.Color;
ACanvas.Font.Assign(Group.Font);
ACanvas.FillRect(CellRect);

CellRect.Left := CellRect.Left + 4;
CellRect.Top := CellRect.Top + 2;
DrawText(ACanvas.Handle, PChar(Text), Length(Text), CellRect, DT_LEFT or DT_WORDBREAK or DT_EXPANDTABS or DT_NOPREFIX or DT_VCENTER)
Zur Erklärung: In meinem Test wird die Gruppenzeile rechtsbündig ausgegeben. Offensichtlich wird dafür die Einstellung der ersten Spalte des Grids übernommen. Ich habe deshalb das Zeichnen selbst übernommen und die Gruppenzeile linksbündig angezeigt.

Mehr habe ich erst mal nicht getestet, da ich für meine Gruppierung noch nicht so weit bin. Es geht vielleicht auch noch etwas einfacher, aber als Anfang sollte es erst mal reichen.

Mike


Alle Zeitangaben in WEZ +1. Es ist jetzt 00:27 Uhr.
Seite 1 von 3  1 23      

Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz