Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Programmieren allgemein (https://www.delphipraxis.net/40-programmieren-allgemein/)
-   -   Delphi Delphi Anwendung internationalisieren / Lokalisierungs Toolkits (https://www.delphipraxis.net/211674-delphi-anwendung-internationalisieren-lokalisierungs-toolkits.html)

BastiFantasti 21. Okt 2022 08:19

Delphi Anwendung internationalisieren / Lokalisierungs Toolkits
 
Hallo zusammen,

wie erstellt ihr mehrsprachige Delphianwendungen?
Wir verwenden seit sehr langer Zeit den Localizer von Korzh

Der funktioniert meißtens ganz gut, wirft einem aber von Zeit zu Zeit auch diverse Knüppel zwischen die Beine...

Deshalb meine Frage nach eventuellen Alternativen :)
Was benutzt ihr und seid ihr damit zufrieden?


Viele Grüße
Bastian

johndoe049 21. Okt 2022 08:49

AW: Delphi Anwendung internationalisieren / Lokalisierungs Toolkits
 
Zitat:

Zitat von BastiFantasti (Beitrag 1513586)
Hallo zusammen,

wie erstellt ihr mehrsprachige Delphianwendungen?
Wir verwenden seit sehr langer Zeit den Localizer von Korzh

Der funktioniert meißtens ganz gut, wirft einem aber von Zeit zu Zeit auch diverse Knüppel zwischen die Beine...

Deshalb meine Frage nach eventuellen Alternativen :)
Was benutzt ihr und seid ihr damit zufrieden?


Viele Grüße
Bastian

Ich verwende zwei Arten

- MUI Anwendung über Resourcen Text. D.h. die Übersetzungen sind in Resourcen gespeichert. In einem aktuellen Lazarus Projekt geht das über TranslateUnitResourceStrings und SetDefaultLang. Delphi Entsprechung müsste ich jetzt auch suchen. Ist aber relativ einfach.

- Datenbank und Textzuweisung über Datenbankabfrage. D.h. jeder Text, jedes Label hat eine Grundbezeichnung und der Rest geht über SQL Abfrage aus einer Datenbank. Etwas aufwendiger als über Resourcen.

Auswahl der Methode ist bei uns Kundenabhängig. Nachdem einer unserer Kunden einen Resourcentext sinnfrei geändert hat haben wir die zweite Methode eingeführt. Da wird dann auf Länge des Textes geprüft.

PaPaNi 21. Okt 2022 10:02

AW: Delphi Anwendung internationalisieren / Lokalisierungs Toolkits
 
1. wir verwenden DxGetText (.po - Dateien)
2. ich persönlich, Ja, zufrieden. Ob mein Teamleiter auch damit zufrieden ist, kann ich nicht sagen. :-D

Uwe Raabe 21. Okt 2022 10:47

AW: Delphi Anwendung internationalisieren / Lokalisierungs Toolkits
 
Zitat:

Zitat von BastiFantasti (Beitrag 1513586)
Wir verwenden seit sehr langer Zeit den Localizer von Korzh

Der funktioniert meißtens ganz gut, wirft einem aber von Zeit zu Zeit auch diverse Knüppel zwischen die Beine...

Den verwende ich auch. Was für Knüppel sind das denn?

BastiFantasti 21. Okt 2022 10:57

AW: Delphi Anwendung internationalisieren / Lokalisierungs Toolkits
 
Zitat:

Zitat von Uwe Raabe (Beitrag 1513600)
Zitat:

Zitat von BastiFantasti (Beitrag 1513586)
Wir verwenden seit sehr langer Zeit den Localizer von Korzh

Der funktioniert meißtens ganz gut, wirft einem aber von Zeit zu Zeit auch diverse Knüppel zwischen die Beine...

Den verwende ich auch. Was für Knüppel sind das denn?


Wir verwenden den Localizer größtenteils im "OnTheFly" Modus in verbindung mit der "UseSoftMode" Option.
D.h. er greift direkt auf die .lng Dateien zu und nicht auf die Sprach DLL Dateien (.ENU, .NTV, ...).

Da gibt es dann die Besonderheit, dass in der zu lokalisierenden Unit die LocOnFly unit in den uses enthalten sein muss. Zusätzlich muss man resourcestrings mit LocStr(@S_Name) verwenden - was man gerne mal vergisst :?.
Und externe Resourcen werden nicht automatisch übersetzt. Diese müssen mit TranslateXS explizit übersetzt werden.
Warum dies bei uns im Code so verwendet wird und ob der besagte SoftMode wirklich Vorteile bringt kann ich nicht sagen.

Dies wurd von meinem Vorgänger so implementiert, der allerdings schon seit mehreren Jahren in Rente ist :thumb:

dummzeuch 21. Okt 2022 12:36

AW: Delphi Anwendung internationalisieren / Lokalisierungs Toolkits
 
Ich/mein Team verwenden DxGetttext + Gorm als Editor für po-Dateien.

Aber das ist nur was für Win32-Programme. Sobald man Win64 (habe ich nicht getestet) oder sonstige Plattformen unterstützen will, funktioniert das nicht mehr.

Und außerdem wird DxGettext nicht mehr gepflegt. Soweit ich weiß, bin ich der einzige, der noch Schreibzugriff auf das Repository auf Sourceforge hat. Alle anderen haben wohl das Interesse verloren. Einen aktuellen Installer gibt es auch nicht mehr.

haentschman 21. Okt 2022 13:17

AW: Delphi Anwendung internationalisieren / Lokalisierungs Toolkits
 
Hallöle...8-)

Alle Plattformen...https://www.tsilang.com/

TurboMagic 22. Okt 2022 16:37

AW: Delphi Anwendung internationalisieren / Lokalisierungs Toolkits
 
Das hier gibt's auch noch:
http://www2.multilizer.com/

Unterstützt VCL und FMX, auch auf Mobile.
Wer mit Übersetzungsbüros zu tun hat wird evtl. den TMX und XLF SUpport schätzen.

zeras 22. Okt 2022 18:44

AW: Delphi Anwendung internationalisieren / Lokalisierungs Toolkits
 
Zitat:

Zitat von haentschman (Beitrag 1513617)
Hallöle...8-)

Alle Plattformen...https://www.tsilang.com/


Wir auch.

Redeemer 24. Okt 2022 07:21

AW: Delphi Anwendung internationalisieren / Lokalisierungs Toolkits
 
Warum hassen alle so die integrierten Übersetzungstools von Delphi?

Uwe Raabe 24. Okt 2022 10:07

AW: Delphi Anwendung internationalisieren / Lokalisierungs Toolkits
 
Hassen ist jetzt der falsche Begriff. Aus eigener Erfahrung kann ich nur sagen, dass sie im Vergleich zu einigen anderen Tools sehr viel schwerfälliger zu bedienen sind und in kaum mehr als "Hello World" Applikationen schnell überfordert sind. Sie werden auch seit geraumer Zeit etwas stiefmütterlich behandelt, weil die Kapazitäten dafür einfach nicht vorhanden sind. Ich persönlich sehe einfach die Gefahr, dass sie in naher bis mittlerer Zukunft durch eine andere Lösung (evtl. einen Zukauf) ersetzt oder einfach abgeschafft werden.

Im Laufe der Zeit habe ich schon einige Lösungen eingesetzt, darunter sowohl die bordeigenen als auch DxGetText. Einige davon gibt es schon lange nicht mehr.

Der Korzh Localizer ist bei mir nun schon seit 2001 im Einsatz. Es mag mittlerweile durchaus bessere Alternativen geben, aber ich habe ihn mithilfe eigener Tools eng in meinen Entwicklungsprozess eingebunden und er liefert immer noch alles was ich benötige. Ergänzungen und Anpassungen von Übersetzungen sind weitestgehend automatisiert und erfordern nur einen geringen manuellen Aufwand. Obwohl ich mir immer wieder neue oder andere Lösungen anschaue, rechtfertigen bislang die eventuellen Vorteile nicht den erforderlichen Wechselaufwand. Aber jeder hat da sicher seine eigene Umgebung, in der das durchaus anders bewertet werden kann.

MyRealName 24. Okt 2022 10:35

AW: Delphi Anwendung internationalisieren / Lokalisierungs Toolkits
 
Ich hatte mir mal eine Komponente dazu geschrieben, die ein eigenes Dateiformat dazu genutzt hat (ein Format für SQL und Sprache, ein anderes f+r Binärdateien). Komponente hat man auf das Formular gelegt und dann im eigenen Editor Captions etc der GUI Elemente mit ID's verbunden. Da konnte man dann zur Laufzeit die Sprache der Anwendung wechseln und hat in allen offenen Forms eine nachricht bekommen über ein Event und konnte zu den Standart-Sachen auch unbeaknnte Komponenten umstellen auf die neue Sprache.
Das war auch garnicht so schwer selbst zu bauen.

Redeemer 24. Okt 2022 10:59

AW: Delphi Anwendung internationalisieren / Lokalisierungs Toolkits
 
Ja gut, die haben ein paar Seltsamkeiten, aber ich habe mir dann ein paar Tools gebaut und seitdem geht das eigentlich auch mit großen Projekten sehr gut. Nur sowas wie ListView- und TreeView-Standardeinträge kriegen die nicht hin, aber das dürfte auch kein Tool schaffen bei dem Blödsinn, den Delphi in der DFM speichert.

MyRealName 24. Okt 2022 11:02

AW: Delphi Anwendung internationalisieren / Lokalisierungs Toolkits
 
Man sollte sowas eh nicht in der DFM speichern, weil Du neu compilieren musst, um etwas hinzuzufügen und es ist nicht so einfach suchbar.

Redeemer 24. Okt 2022 11:49

AW: Delphi Anwendung internationalisieren / Lokalisierungs Toolkits
 
Mach ich auch nicht. Mein größtes Problem mit den Delphi-Lokalisierungstools ist der Bug, dass es sich regelmäßig selbst die XMLs zerschießt, indem es vergisst, den Wert für das Attribut "id" zu schreiben. Kopiert man dann von dem einzigen anderen Attribut des fehlerhaften Tags und dann geht es auch wieder.

Ich hab mir dann ein Tool erstellt, das zusammen mit ResHacker aus den Kompilaten eine lokalisierte EXE baut. Ich brauche dann keinen Code schreiben und das Programm besteht weiterhin für alle User nur aus einer einzigen EXE. Bei solider Komprimierung wird das Projekt bleiben die verschiedenen EXEn im Installer auch schön klein.

philipp.hofmann 24. Okt 2022 12:33

AW: Delphi Anwendung internationalisieren / Lokalisierungs Toolkits
 
Ich mache es auch ähnlich wie MyRealName, jedes Element hat eine ID für den Text und eine ID für den Hint und diese habe ich in einer extra Datei abgespeichert, die für jede Sprache vorliegt und der Kunde kann on-the-fly die Sprache wechseln (was jetzt mehr für mich beim Testen bzw. dokumentieren ein interessantes Feature ist und ich kann die Datei auch on-the-fly austauschen). Ich habe es übrigens so gebaut, dass ich auch die Sprache XX auswählen kann und dann werden mir die IDs an allen Elementen angezeigt, so dass man auch relativ schnell als Nicht-Programmierer herausfinden kann, auf welche ID man hier gerade schaut.

Das ganze war keine 4 Stunden Arbeit an Programmierung, die Hauptarbeit geht auf die Übersetzung an sich drauf.

Bbommel 24. Okt 2022 12:36

AW: Delphi Anwendung internationalisieren / Lokalisierungs Toolkits
 
Zitat:

Zitat von dummzeuch (Beitrag 1513611)
Ich/mein Team verwenden DxGetttext + Gorm als Editor für po-Dateien.

Aber das ist nur was für Win32-Programme. Sobald man Win64 (habe ich nicht getestet) oder sonstige Plattformen unterstützen will, funktioniert das nicht mehr.

Ich nutze die von dir gepflegte gnugettext.pas auch in Win64-VCL-Programmen - funktioniert auch damit völlig problemlos.

Für Linux musste ich etwas an der gnugettext.pas rumbasteln, einige Funktionen rausschmeißen oder "lahmlegen". Aber das, was ich in dem Fall noch brauche (im Wesentlichen ist das bei einem WebBroker-Projekt dann der Aufruf der Funktion "_", um übersetzte Texte zu holen und an den Client zu senden), funktioniert letztlich auch unter Linux problemlos - hat mich selber etwas überrascht.

Falls mal Lust und Zeit ist, können wir auch gerne mal zusammen versuchen, diese etwas rabiaten Änderungen von mir ordentlich zu machen und in IFDEFs zu überführen, um sie dann so ins Repository aufzunehmen und der Allgemeinheit zur Verfügung zu stellen.

dummzeuch 24. Okt 2022 14:36

AW: Delphi Anwendung internationalisieren / Lokalisierungs Toolkits
 
Zitat:

Zitat von Bbommel (Beitrag 1513726)
Zitat:

Zitat von dummzeuch (Beitrag 1513611)
Ich/mein Team verwenden DxGetttext + Gorm als Editor für po-Dateien.

Aber das ist nur was für Win32-Programme. Sobald man Win64 (habe ich nicht getestet) oder sonstige Plattformen unterstützen will, funktioniert das nicht mehr.

Ich nutze die von dir gepflegte gnugettext.pas auch in Win64-VCL-Programmen - funktioniert auch damit völlig problemlos.

Für Linux musste ich etwas an der gnugettext.pas rumbasteln, einige Funktionen rausschmeißen oder "lahmlegen". Aber das, was ich in dem Fall noch brauche (im Wesentlichen ist das bei einem WebBroker-Projekt dann der Aufruf der Funktion "_", um übersetzte Texte zu holen und an den Client zu senden), funktioniert letztlich auch unter Linux problemlos - hat mich selber etwas überrascht.

Falls mal Lust und Zeit ist, können wir auch gerne mal zusammen versuchen, diese etwas rabiaten Änderungen von mir ordentlich zu machen und in IFDEFs zu überführen, um sie dann so ins Repository aufzunehmen und der Allgemeinheit zur Verfügung zu stellen.

Das mit der Zeit ist immer so eine Sache... Aber Du könntest mir mal Deine Version zukommen lassen, vielleicht sind die Unterschiede ja gar nicht so groß und man braucht nur ein paar IFDEFS drübersprenkeln. Ich kann das aber für Linux nicht testen. Für Win64 könnte ich testen, ob es compiliert, zu testen, ob es funktioniert, ist dann schon wieder zeitaufwändiger.

Bbommel 25. Okt 2022 09:27

AW: Delphi Anwendung internationalisieren / Lokalisierungs Toolkits
 
Zitat:

Zitat von dummzeuch (Beitrag 1513736)
Das mit der Zeit ist immer so eine Sache... Aber Du könntest mir mal Deine Version zukommen lassen, vielleicht sind die Unterschiede ja gar nicht so groß und man braucht nur ein paar IFDEFS drübersprenkeln. Ich kann das aber für Linux nicht testen. Für Win64 könnte ich testen, ob es compiliert, zu testen, ob es funktioniert, ist dann schon wieder zeitaufwändiger.

Bei mir ist in dieser Woche die Zeit auch etwas knapp, weil ich noch ein Projekt halbwegs fertig bekommen will. Aber ich habe mir mal eine Erinnerung in den Kalender eingetragen, damit ich das mal in Ruhe aufbereiten kann (du musst ja nicht Dinge aufbereiten, die ich mir vorher selber schon anschauen kann) und melde mich dann per Mail bei dir.

BigAl 25. Okt 2022 10:51

AW: Delphi Anwendung internationalisieren / Lokalisierungs Toolkits
 
Liste der Anhänge anzeigen (Anzahl: 1)
Da ich Anwendungen schreibe die weltweit im Einsatz sind mache ich die Lokalisierung seit über 20 Jahren selbst. Die Texte sind dabei in einer Datenbank gespeichert. Meist MSSQL aber z.T. auch in AbsoluteDB wenn keine größere Datenbank erforderlich ist. Dafür habe ich mir auch verschiedene Tools geschrieben für export und import von Übersetzungen, da wir diese meist von den Kunden machen lassen (Ich kann weder chinesisch noch ...). An der Oberfläche nutze ich die TAG-Eigenschaft. Ist ein Tag = 1, dann wird der entsprechende Text beim Laden des Formulars übersetzt. Weiterhin habe ich eine globale Umschaltung für Fettschrift implementiert, da diese je nach Sprache (Zeichensatz) anpassbar sein sollte. Das mache ich dann mit Tag = 1 oder Tag = 2.

In der Datenbank habe ich dann z.B. folgende Felder:

LangID (Sprachkennung)
Part (z.B. der Form-Name oder aber auch GLOBAL für globale Texte, ALARM für Alarmtexte etc.)
Entry (z.B. der Name der Komponente oder aber auch sonstige Kennungen wie "ALARM0001" oder "strYes")
Text (der zur Sprachkennung passende Text)

Ich habe auch einen Standarddialog erstellt, der es dem Endkunden erlaubt Texte zur Laufzeit anzupassen. Das ist erforderlich, da oftmals die Übersetzung vom Kontext abhängt.

Geladen wird immer ein kompletter Part. Es ist also für die Übersetzung eines kompletten Forms (Dialog...) nur ein SQL-Zugriff erforderlich.

Das ganze geht ohne merkliche Verzögerung und läuft sehr zuverlässig. Ich schreibe das, da ich mich über die Jahre - bis auf ein paar Ausnahmen - von gekauften Bibliotheken unabhängig gemacht habe. In der Vergangenheit wurden leider immer wieder tolle Komponenten vom Markt genommen.

Soviel vielleicht mal als Anreiz sowas "zu Fuß" zu machen.

Der Spracheditor präsentiert sich z.B. so:

Anhang 55495


Alle Zeitangaben in WEZ +1. Es ist jetzt 04:18 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