AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

Fastreport DBGrid

Ein Thema von Jick · begonnen am 12. Mär 2014 · letzter Beitrag vom 14. Mär 2014
Antwort Antwort
Jick

Registriert seit: 12. Jun 2011
26 Beiträge
 
Delphi XE Starter
 
#1

Fastreport DBGrid

  Alt 12. Mär 2014, 12:54
Hallo,

ich drucke ein DBGrid (Jedi) mit Hilfe eines Crosstab aus und bin am verzweifeln einzelne Spalten auszurichten.
Leider habe ich nur die Fastreport Basic Variante und dort gibt es nicht die Möglichkeit über OnPrintCell-Event die
Spalten zu formatieren.
Gibt es eine Möglichkeit während der Laufzeit die Spalten zu formatieren oder eine andere Variante wie ich das schon formatierte
DBGrid mit Fastreport ausdrucken kann ?

Grüße
Michael
  Mit Zitat antworten Zitat
Benutzerbild von sx2008
sx2008

Registriert seit: 16. Feb 2008
Ort: Baden-Württemberg
2.332 Beiträge
 
Delphi 2007 Professional
 
#2

AW: Fastreport DBGrid

  Alt 12. Mär 2014, 13:16
Jedes Datenbankfeld (Basisklasse TField) kennt das Event OnGetText.
Damit kann man über einen Eventhandler die Textrepräsentation des Feldes beliebig formatieren.
Man könnte z.B. aus einem Integerfeld mit dem Wert 2380 den Text "2,380 ms" erzeugen.
fork me on Github
  Mit Zitat antworten Zitat
EarlyBird

Registriert seit: 29. Mär 2007
235 Beiträge
 
#3

AW: Fastreport DBGrid

  Alt 12. Mär 2014, 14:13
Ich kenne die Fastreport Basic Variante nicht.
In meiner Version kann man eine Zelle im Crosstab auswählen.
Dann unter Eigenschaften "Memo" auswählen.
Dort unter "Highlight" die Bedingung für die Formatierung angeben.
oder:
kein CrossTab verwenden sonder mit Memos und Rahmen arbeiten und Hightlight der Memos nutzen

Eventuell hilft Dir das ja weiter.

Geändert von EarlyBird (12. Mär 2014 um 14:16 Uhr)
  Mit Zitat antworten Zitat
Jick

Registriert seit: 12. Jun 2011
26 Beiträge
 
Delphi XE Starter
 
#4

AW: Fastreport DBGrid

  Alt 12. Mär 2014, 23:14
Hallo,

das Problem ist das ich nicht weiß wie viele Spalten es zur Laufzeit gibt und deshalb kann ich es nicht im Report vorher schon definieren.
Irgendwie muss es doch eine Möglichkeit geben zu sagen das Spalte 1 Rechtsbündig ausgerichtet werden soll.

Grüße
Michael
  Mit Zitat antworten Zitat
Furtbichler
(Gast)

n/a Beiträge
 
#5

AW: Fastreport DBGrid

  Alt 13. Mär 2014, 08:43
Die Fragestellung ist etwas merkwürdig.
1. Man druckt kein DBGrid aus, sondern erstellt eine eigene Tabelle in FastReport auf Grundlage von Datenmengen (TDataSet).
2. Bei einer Kreuztabelle ist ja gerade der Witz der, das man die Spalten zur Laufzeit erstellt. Das liegt in der Natur der Sache.

Einerseits hast Du ein TDBGrid, andererseits eine Kreuztabelle. Was denn nun?

Wenn Du eine Crosstab hast und die erste Spalte statisch rechtsbündig ausrichten willst, versuche, die Query so umzuformen, das die erste Spalte als eigene Spalte erscheint (denn die ist ja dann auch statisch). Eventuell kommst du dann weiter (aber ich sehe nicht direkt, wie).

Aber es scheint mit Mühe zu gehen, vermutlich über Umwege: Man kann den fertig gerenderten Report ja auch nachträglich per Delphi-Code durchsuchen und entsprechende Komponenten anfassen. Hier müsstest Du an die erste Spalte deines Crosstab-Objekts herankommen.
  Mit Zitat antworten Zitat
EarlyBird

Registriert seit: 29. Mär 2007
235 Beiträge
 
#6

AW: Fastreport DBGrid

  Alt 13. Mär 2014, 10:46
Sende doch mal ein Bild wie es aussehen soll
Vielleicht hilft Dir auch folgendes: Creating a report from Code

Geändert von EarlyBird (13. Mär 2014 um 12:13 Uhr)
  Mit Zitat antworten Zitat
Jick

Registriert seit: 12. Jun 2011
26 Beiträge
 
Delphi XE Starter
 
#7

AW: Fastreport DBGrid

  Alt 14. Mär 2014, 12:34
Anbei mal ein Bild wie es jetzt mit einem Crosstab aussieht.
Die Gesamtsumme will ich rechts ausrichten.

Delphi-Quellcode:
procedure TfrmAuswertung.frxReport1BeforePrint(Sender: TfrxReportComponent);
//CrossView füllen
var
  Cross: TfrxCrossView;
  i, j: Integer;
  s: string;
begin
  if Sender is TfrxCrossView then
  begin
    Cross := TfrxCrossView(Sender);
    DBGrid1.DataSource.DataSet.First;
    i := 0;
    while not DBGrid1.DataSource.DataSet.Eof do
    begin
      for j := 0 to DBGrid1.DataSource.DataSet.Fields.Count - 1 do
      begin
        if (DBGrid1.DataSource.DataSet.Fields[j] is TFloatField) then
        begin
          s := format('%.2f',[DBGrid1.DataSource.DataSet.Fields[j].AsFloat]);
          Cross.AddValue([i], [DBGrid1.DataSource.DataSet.Fields[j].DisplayLabel],
            [s]);
        end
        else
        begin
          Cross.AddValue([i], [DBGrid1.DataSource.DataSet.Fields[j].DisplayLabel],
            [DBGrid1.DataSource.DataSet.Fields[j].AsString]);
        end;
      end;
      DBGrid1.DataSource.DataSet.Next;
      Inc(i);
    end;
  end;
end;
Miniaturansicht angehängter Grafiken
unbenannt.png  
  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 03:14 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 by Thomas Breitkreuz