![]() |
DevExpress Summe
Hallo,
ich möchte im DevExpress Grid in der Gruppenfusszeile bei jeder neuen Berechnung die Ausgabe formatieren. Die Spalte ist in hh:mm formatiert. Die Summe wird aber dez ausgegeben. Jetzt möchte ich bei jeder Änderung(Neuberechnung) den Wert formatieren und dann überschreiben. Welches Ereignis nehme ich? DataController.SummaryFooterSummaryItems.OnSummary ? Wie wird der Wert ausgelesen und dann überschrieben ? Benutze Delphi 7 Danke schon mal - Lothar |
Re: DevExpress Summe
Hallo,
wenn du dir ein Footer erstellst, dann nimm doch das Event GetText vom Summary-Item als Beispiel ...
Delphi-Quellcode:
Den Wert entnimmst du von AValue, den du dann bei AText formatiert darstellen kannst. Ich hoffe du kannst damit etwas anfangen.
TcxGridDBDataController.TcxDataSummary.FooterSummary.Items[0].GetText(Sender: TcxDataSummaryItem; const AValue: Variant; AIsFooter: Boolean; var AText: string)
Gruß Matze |
Re: DevExpress Summe
Hi, das klappt. Danke schon mal.
So kann ich die Fusszeilensumme formatieren. Was ich allerdings noch brauche ist die GRUPPENfusszeilensumme. D.h. ich ziehe eine Spalte nach oben um danach zu gruppieren. z.B. Name Dann blende ich die Gruppenfusszeile ein und dann die Summe. Dann habe ich ein SummeFeld unter jeder Gruppierung. Das müsste ich ebenfalls formatieren. Grüsse Lothar |
Re: DevExpress Summe
Den Footer kannst schon im Designer Mode einschalten.
Vom TableView die Optionview.Footer auf True stellen. Wenn du da schon bist, dann bitte für die Gruppensummen den Groupfooter auf gfVisibleWhenExpanded oder gfAlwaysVisible Sonst mußt du sie immer erst einschalten. Für die Gruppensummen wieder in die Summary gehen, aber diesmal zu den Groups. Dort stellst du die Gruppensummen ein. Zuerst mußt du eine Gruppe erstellen und danach ein Item. Nur noch vom Item die Spalte zuweisen, wo die Summe dargestellt werden soll. (Name soll ja gruppiert werden, die Spalte also nicht). Als Kind skCount einstellen. Unten siehst du zwei Frames Unlinked und Linked Columns. Dort mußt du die Spalte mit dem Namen zuweisen. Also bei Linked Columns sollte das Feld stehen, was summiert werden soll. Dann sollte es so sein wie du es möchtest. Gruß Matze |
Re: DevExpress Summe
Hi,
müsste man schon im Quellcode machen, denn das Gruppieren ist ja flexibel. Ich müsste mitbekommen das eine Gruppenfusssumme angezeigt wird und dann formatieren. Ist warscheinlich schwer zu verstehen.Oder ich versteh es nicht.Kann auch sein. Die Spalte die summiert wird kenn ich, die ist fest.Nur wenn die summiert wird möcht ich foratieren. Nur wie gruppiert wird weiss ich nicht. Deshalb bräuchte ich das Ereignis das gruppiert wurde und eine Summe angezeigt wird. Dann müsste man das Feld abfragen, umformatieren und neu zuweisen. Aber schon mal danke - Lothar |
Re: DevExpress Summe
Möchtest du nur die Gruppierung in Code machen oder ist die Gruppierung schon vorhanden und es soll nur im Code formatiert werden?
Erstens ist schon schwieriger, aber das Event OnGetText ist das was du suchst. Bei zweitens ist es ein bißchen einfacher, natürlich auch wieder OnGetText. Wie du eine Gruppe erstellst habe ich ja beschrieben. (Die soll ja fest sein, oder?) Eine Spalte im Designer Mode kannst du gruppieren wenn du direkt in der Spalte (z. B. TcxGridDBColumn o. ä.) den Groupindex von -1 auf 0 änderst (abhängig wieviel Gruppen du erstellst hast), dann Visible auf False stellen, sonst siehst du die gruppierte Spalte auch im Grid und nicht nur in der Gruppierungsbox. Gruß Matze |
Re: DevExpress Summe
Zitat:
Nur die Formatierung der Spalte Summe(Zeit) von Float in hh:mm ist vorgegeben. Wenn jetzt nach z. B. Name, id o.a. gruppiert wird und die Gruppenfusszeile + Summe eingeblendet wird (Laufzeit) dann wird die Summe anstatt 01:35 als 95,00 angezeigt. Das müsste dann formatiert werden. Hoffe ist so klarer.Auf jeden Fall danke für deine Hilfe und deine Geduld.Hab das Programm mit dem Grid erst vor kurzem übernommen und fische noch sehr im Trüben. Grüsse Lothar |
Re: DevExpress Summe
Liste der Anhänge anzeigen (Anzahl: 2)
Ich hoffe ich habe dich richtig verstanden ...
Ich habe mal ein kleines Beispiel erstellt. Jedoch habe ich alle Groups und Items schon angelegt, dadurch habe ich jetzt das geforderte Event und kann formatieren. Es sind keine Gruppierung vorgegeben, du kannst ausser der Zeit-Spalten alles gruppieren. Im Footer der Gruppe siehst du das formatierte Ergebnis. Stellvertretend für viele Event habe ich nur ein Event GetText angelegt und im OI bei OnGetText zugewiesen. Siehe Bild im Anhang. Mit der rechten Maustaste kannst du jetzt auf der Caption der Spalte das Zusatzmenü öffnen. Dort kannst du die Gruppierung auswählen, auch mehrfach Gruppierungen sind erlaubt. Gruß Matze PS Kein Problem :) Edit : neues Beispiel Projekt hochgeladen - jetzt ohne Skins bei Uses ... |
Re: DevExpress Summe
Hi, habs ausprobiert und funktioniert bis auf eine Einschränkung sehr gut.
Vielen Dank schon mal :bounce2: Wenn ich es richtig verstanden habe muss ich alle Spalten nach denen gruppiert werden kann im OI zuweisen.Ist machbar. Das was nicht funktioniert ist wenn man nach dem Aufruf die Summe in der Gruppenfußzeile mit der rechten Maustaste aus und dann wieder einblendet. Dann ist die Formatierung nicht mehr da :gruebel: Ist auf jeden Fall ne Herausforderung dieses Grid mit all seinen Möglichkeiten. :pale: |
Re: DevExpress Summe
Du hast recht, das ist ja doof.... Ich melde mich wieder
Gruß Matze |
Alle Zeitangaben in WEZ +1. Es ist jetzt 18:51 Uhr. |
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024-2025 by Thomas Breitkreuz