![]() |
AW: Fastreport, mehrsprachige Reports
Zitat:
Ich habe es gerade getestet und es funktioniert wie gewünscht. Ich werde es nun mit der registrierten Funktion implementieren. So kann ich die Übersetzungen gut in der Datenbank speichern und bei bedarf anpassen ohne den Report zu ändern. Und ich brauche nur einen Report für viele Sprachen :-D Noch eine weitere Frage: Übergebt Ihr alle möglichen Konstanten aus dem Wörterbuch an den Report damit sie als Auswahlliste im Designer zur Verfügung stehen? Und Wenn ja wie? |
AW: Fastreport, mehrsprachige Reports
nein, wir geben den konstantennamen zurück, wenn es keine übersetzung exstiert. wir haben allerdings eine möglichkeit implementiert, vom reportdesigner aus in unser wörterbuch zu schauen, damit man weiß welche konstanten bereits vorhanden sind und somit automatisch übersetzt werden.
das andere bsp (wurde hier auch schon einmal vorgeschlagen) haben wir aber auch implementiert: darin werden alle felder übersetzt, in abhängigkeit dessen was im listenlayout hinterlegt wurde. man hat aber dadurch das problem "zufälliger übersetzungen"
Code:
For I:=0 to frxReport1.ComponentCount-1 do
If (frxReport1.Components[I] IS TfrxMemoView)then begin If not (Sender=btDesignReport) then//keine Übersetzung der Captions im Designer! (frxReport1.Components[I] AS TfrxMemoView).Memo.Text:=DM1.GetFieldAlias(Trim((frxReport1.Components[I] AS TfrxMemoView).Memo.Text)); (frxReport1.Components[I] AS TfrxMemoView).DisplayFormat.DecimalSeparator:=FormatSettings.DecimalSeparator; If (frxReport1.Components[I] AS TfrxMemoView).Frame.Width=1 then (frxReport1.Components[I] AS TfrxMemoView).Frame.Width:=0.1; end |
AW: Fastreport, mehrsprachige Reports
Zitat:
Damit sieht man sofort wo etwas fehlt Zitat:
So eine List würde ja schon mal viel helfen beim erstellen der Reports |
AW: Fastreport, mehrsprachige Reports
...letztendlich über ein form, welche mittels hotkey aufgerufen kann und ein Memdataset in form eines Grids darstellt. ;)
als zB über einen timer und GetASyncKeystate, formStyle StayOnTop |
AW: Fastreport, mehrsprachige Reports
Wir haben das wie folgt gelöst (es wird Localizer eingesetzt, aber die Funktion GetTranslatedProperty sowie die Native-Abfrage kann ja leicht angepasst werden). Die Funktion wird dann vor dem ShowReport oder PrepareReport aufgerufen.
Delphi-Quellcode:
procedure PrepareFrx(Report : TFrxReport);
//------------------------------------------------------------------------ // Abfrage der Strings aus Localizer //------------------------------------------------------------------------ function GetTranslatedProperty(const FormName, PropertyName : string): string; begin Result := LocOnFly.LocalizerOnFly.GetTranslatedProperty(Formname, PropertyName); end; var i : integer; ResString : widestring; FormName, CompName : string; Native : boolean; begin // Feststellen, ob übersetzt werden müss Native := (LocalizerOnFly.NativeLocale = LocalizerOnFly.CurrentLocale); // Name der Elternkomponente, sollte immer das Formular sein ... if Report.Owner <> nil then Formname := Report.Owner.Name; // Alle Reportkomponenten durchlaufen for i := 0 to Report.ComponentCount-1 do begin // wenn es ein Textfeld ist if TFrxComponent(Report.Components[i]) is TFrxMemoView then begin // Die Spezialfälle eintragen, die müssen dann so heißen CompName := Lowercase(TFrxComponent(Report.Components[i]).Name); if CompName = 'qrluser' then TFrxMemoView(Report.Components[i]).Memo.Text := UserName else if CompName = 'qrlprogramname' then TFrxMemoView(Report.Components[i]).Memo.Text := ProgramName+' '+CopyRight else if CompName = 'qrlversion' then TFrxMemoView(Report.Components[i]).Memo.Text := ProgramVersion else if not Native then begin // Wenn Übersetzung notwendig, dann den übersetzten String holen // ResString := LocOnFly.LocalizerOnFly.GetTranslatedProperty(Formname,TFrxComponent(Report.Components[i]).Name+'.Memo.UTF8'); ResString := GetTranslatedProperty(Formname,TFrxComponent(Report.Components[i]).Name+'.Memo.UTF8'); // und eintragen if ResString <> '' then TFrxMemoView(Report.Components[i]).Memo.Text := ResString; // wichtig, da UTF8 keine CHARSETS verträgt! Localizer trägt aber // beim Einlesen der Übersetzung das Charset der Zielsprach-Lokale ein. // Also DEFAULT_CHARSET setzen TFrxMemoView(Report.Components[i]).Font.Charset := 1; end; end; end; if frmData.tblSetup.FieldByName('WaterMark').AsString <> '' then CreateReportWaterMark(Report, frmData.tblSetup.FieldByName('WaterMark').AsString); end; |
AW: Fastreport, mehrsprachige Reports
Zitat:
Mit folgendem Code füge ich meine Konstanten in einer Combobox in der Toolbar des Designers ein. Ob alles funktioniert muss ich aber noch Testen. Angezeigt wird die Combobox mit den Konstanzen schon.
Delphi-Quellcode:
und mit folgendem Code kann man einen weitern Tab im Databaum hinzufügen und die Konstanten z.B in einer Listbox anzeigen
var
designer: TfrxDesignerForm; myDesigner: TfrxCustomDesigner; cbb2: TComboBox; tlb2: TToolBar; begin myDesigner := TfrxCustomDesigner(frxDesignerClass.NewInstance); myDesigner.CreateDesigner(nil, frxReport); frxReport.Designer := MyDesigner; designer := TfrxDesignerForm(frxReport.Designer); cbb2 := TComboBox.Create(Self); tlb2 := TToolBar.create(self); tlb2.Parent:= Designer.DockTop; cbb2.Parent := tlb2; cbb2.Items.Add('Anzahl'); cbb2.Items.Add('Ausfuehrung'); cbb2.Items.Add('Box'); cbb2.Items.Add('Breite'); cbb2.Items.Add('Durchmesser'); cbb2.Items.Add('Waage'); Designer.Showmodal;
Delphi-Quellcode:
Ist alles noch nicht perfekt aber der Ansatz gefällt mit gut
lb_Constanten := TListBox.Create(self);
Pn_Constanten := TPanel.Create(Self); Designer.Show; for x := 0 to Designer.DataTree.ControlCount - 1 do begin myClassname := Designer.DataTree.Controls[x].ClassType.ClassName; if myClassname = 'TTabSet' then begin MyTabs := TTabSet(Designer.DataTree.Controls[x]); Break; end; end; Pn_Constanten.parent := Designer.DataTree.DataPn.parent; Pn_Constanten.Align := Designer.DataTree.DataPn.Align; Pn_Constanten.BoundsRect := Designer.DataTree.DataPn.BoundsRect ; Pn_Constanten.Visible := False; lb_Constanten.Parent := Pn_Constanten; MyTabs.Tabs.AddObject('TransLations', Pn_Constanten); lb_Constanten.Items := cbb2.Items; lb_Constanten.Align := alClient; Designer.DataTree.UpdateItems; Jetzt möchte ich natürlich noch die Translate Funktion per doppelklick auf die Combobox oder Listbox in die Memos schreiben. Hat da jemand einen Tipp? |
AW: Fastreport, mehrsprachige Reports
Zitat:
Für die die es interessiert
Delphi-Quellcode:
Es gibt noch ein bisschen was zu tun am Code
MyDesigner: TfrxCustomDesigner;
implementation {$R *.dfm} procedure TForm3.btn1Click(Sender: TObject); var ... ... begin MyDesigner := TfrxCustomDesigner(frxDesignerClass.NewInstance); MyDesigner.CreateDesigner(nil, frxReport); //usw wie oben beschrieben procedure lst1DblClick(Sender: TObject); var tranlateStr: string; myMemoView : TfrxMemoView; myListBox : TListBox; begin myListBox := TListBox(Sender); tranlateStr:= myListBox.Items[myListBox.ItemIndex] ; myMemoView := MyDesigner.SelectedObjects.Items[0]; myMemoView.Text := 'TransLate[' + QuotedStr(tranlateStr) +']'; end; aber das Prinzip funktioniert. Jetzt muss ich es nur noch ein bisschen verfeineren Das ganze wird schon eine deutliche Hilfe beim erstellen mehrsprachiger Dokumente. Die Verschiedenen Sprachen speicher ich in einer Datenbank mit den Konstanten Diese kann ich dann immer per doppelklick in ein TfrxMemoView im Fastreport Designer einfügen. Für mich eine sehr gute Lösung. Vielen Dank für all die Tipps und Anregungen :-D |
AW: Fastreport, mehrsprachige Reports
Wenn mal jemand etwas ähnliches machen möchte.
Diesen Code kann man als ersten Ansatz nutzen.
Delphi-Quellcode:
Mir ist schon klar das es noch einiges zu tun und zu verbessern gibt :wink:
unit Unit3;
interface uses Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms, Tabs, Dialogs, ExtCtrls, frxDesgn, frxClass, StdCtrls, ToolWin, ComCtrls; type TForm3 = class(TForm) btn1: TButton; frxreport: TfrxReport; frxDesigner1: TfrxDesigner; pnl1: TPanel; procedure btn1Click(Sender: TObject); procedure lst1DblClick(Sender: TObject); private { Private-Deklarationen } public { Public-Deklarationen } end; var Form3: TForm3; MyDesigner: TfrxCustomDesigner; implementation {$R *.dfm} procedure TForm3.btn1Click(Sender: TObject); var Designer: TfrxDesignerForm; cbb2: TComboBox; tlb2: TToolBar; MyTabs : TTabSet; lb_Constanten: TListBox; Pn_Constanten: TPanel; x : Integer; myClassname : String; mymemp : TfrxMemoView; begin MyDesigner := TfrxCustomDesigner(frxDesignerClass.NewInstance); MyDesigner.CreateDesigner(nil, frxReport); frxReport.Designer := MyDesigner; Designer := TfrxDesignerForm(frxReport.Designer); cbb2 := TComboBox.Create(Self); tlb2 := TToolBar.create(self); tlb2.Parent:= Designer.DockTop; cbb2.Parent := tlb2; cbb2.Items.Add('Anzahl'); cbb2.Items.Add('Ausfuehrung'); cbb2.Items.Add('Box'); cbb2.Items.Add('Breite'); cbb2.Items.Add('Durchmesser'); cbb2.Items.Add('Waage'); lb_Constanten := TListBox.Create(self); Pn_Constanten := TPanel.Create(Self); Designer.Show; for x := 0 to Designer.DataTree.ControlCount - 1 do begin myClassname := Designer.DataTree.Controls[x].ClassType.ClassName; if myClassname = 'TTabSet' then begin MyTabs := TTabSet(Designer.DataTree.Controls[x]); Break; end; end; Pn_Constanten.parent := Designer.DataTree.DataPn.parent; Pn_Constanten.Align := Designer.DataTree.DataPn.Align; Pn_Constanten.BoundsRect := Designer.DataTree.DataPn.BoundsRect ; Pn_Constanten.Visible := False; lb_Constanten.Parent := Pn_Constanten; MyTabs.Tabs.AddObject('TransLations', Pn_Constanten); lb_Constanten.Items := cbb2.Items; lb_Constanten.Align := alClient; lb_Constanten.OnDblClick := lst1DblClick; Designer.DataTree.UpdateItems; end; procedure TForm3.btn2Click(Sender: TObject); begin frxReport.DesignReport; end; procedure TForm3.lst1DblClick(Sender: TObject); var tranlateStr : string; myMemoView : TfrxMemoView; myListBox : TListBox; begin if MyDesigner.SelectedObjects.Count > 1 then begin MessageDlg('Bitte wählen Sie ein einzelnes MemoView aus.', mtInformation, [mbOK], 0); Exit; end; myListBox := TListBox(Sender); tranlateStr := myListBox.Items[myListBox.ItemIndex] ; try myMemoView := MyDesigner.SelectedObjects.Items[0]; myMemoView.Text := 'TransLate[' + QuotedStr(tranlateStr) +']'; MyDesigner.Report.Designer.ReloadReport; MyDesigner.SelectedObjects.Clear; MyDesigner.SelectedObjects.Add(myMemoView) ; except MessageDlg('Das einfügen ist nur iin MemoViews mäöglich', mtInformation, [mbOK], 0); end; end; end. |
Alle Zeitangaben in WEZ +1. Es ist jetzt 06:56 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