AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Sprachen und Entwicklungsumgebungen Sonstige Fragen zu Delphi Delphi TcxGrid und onAfterSummary [Erledigt]
Thema durchsuchen
Ansicht
Themen-Optionen

TcxGrid und onAfterSummary [Erledigt]

Ein Thema von dataspider · begonnen am 18. Nov 2006 · letzter Beitrag vom 18. Nov 2006
Antwort Antwort
Benutzerbild von dataspider
dataspider

Registriert seit: 9. Nov 2003
Ort: 04539 Groitzsch
1.350 Beiträge
 
Delphi 11 Alexandria
 
#1

TcxGrid und onAfterSummary [Erledigt]

  Alt 18. Nov 2006, 13:26
Hallo Experten,

ich versuche nun schon eine Weile, in die Summierung der cxGrid einzugreifen.
Aber irgendwie hqab ich jetzt ein BlackOut.
Ich habe 3 Summenfelder. Gesamt (Index 0), Menge To (Index 2) und Preis (Index 3).
Unter Preis will ich den Durchschnittspreis, der sich aus den Summenwerten Gesamt und MengeTo bildet.

Er rechnet auch richtig, nur fehlen Daten, wenn ich nach mehr als 1 Item gruppiere.
(siehe Anhang - leere Kästchen in der unteren Gruppe)

Sieht vielleich jemand den Fehler ?


Delphi-Quellcode:
procedure TForm1.CalculateGroupAverage(ADataGroupIndex: TcxDataGroupIndex);
var
  AMengeTo, AGesamt, AVarAverage: Variant;

begin
  with gv.DataController.Summary do
  begin
    AMengeTo := GroupSummaryValues[ADataGroupIndex, 2];
    AGesamt := GroupSummaryValues[ADataGroupIndex, 0];
    if not (VarIsNull(AMengeTo) or VarIsNull(AGesamt)) then
    begin
      AVarAverage := AGesamt / AMengeTo;
      GroupSummaryValues[ADataGroupIndex, 3] := FloatToStrF(AVarAverage, ffFixed, 15, 2);
    end;
  end;
end;

procedure TForm1.gvDataControllerSummaryAfterSummary(
  ASender: TcxDataSummary);

var
  AChildDataGroupsCount: Integer;
  AChildDataGroupIndex, AParentDataGroupIndex: TcxDataGroupIndex;
  AChildPosition: Integer;
  i: Integer;
begin
  with TcxDataControllerGroups(gv.DataController.Groups) do
  begin
    for i := 1 to GroupingItemCount do
    begin
      AChildDataGroupsCount := ChildCount[i -2];
      for AChildPosition := 0 to AChildDataGroupsCount - 1 do
      begin
        AChildDataGroupIndex := ChildDataGroupIndex[i -2, AChildPosition];
        CalculateGroupAverage(AChildDataGroupIndex);
      end;
    end;
  end;
end;
Danke, Frank
Miniaturansicht angehängter Grafiken
summary_176.jpg  
Frank Reim
  Mit Zitat antworten Zitat
alzaimar
(Moderator)

Registriert seit: 6. Mai 2005
Ort: Berlin
4.956 Beiträge
 
Delphi 2007 Enterprise
 
#2

Re: TcxGrid und onAfterSummary

  Alt 18. Nov 2006, 14:55
Ich verstehe nicht, wieso Du den Durschnittspreis per Code berechnest. Das TcxGrid kann das doch von Hause aus...
"Wenn ist das Nunstruck git und Slotermeyer? Ja! Beiherhund das Oder die Flipperwaldt gersput!"
(Monty Python "Joke Warefare")
  Mit Zitat antworten Zitat
Benutzerbild von dataspider
dataspider

Registriert seit: 9. Nov 2003
Ort: 04539 Groitzsch
1.350 Beiträge
 
Delphi 11 Alexandria
 
#3

Re: TcxGrid und onAfterSummary

  Alt 18. Nov 2006, 15:03
Zitat von alzaimar:
Ich verstehe nicht, wieso Du den Durschnittspreis per Code berechnest. Das TcxGrid kann das doch von Hause aus...
Das ist ganz einfach.
Wenn ich 2 Positionen habe, einmal Preis 3 und eimal 5, so ist der AVG nqatürlich 4.
Doch das nützt mit gar nichts, denn:

Ich habe
2 to zu 3 € (= 6 €)

und

10 to zu 5 € (=50 €).

Der D-Preis ist 56 € / 12 to = 4,67 € / to.

Cu, Frank
Frank Reim
  Mit Zitat antworten Zitat
Antwort Antwort


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 23:06 Uhr.
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