AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Tutorials Delphi Mehrsprachiges Programm mit *ini
Tutorial durchsuchen
Ansicht
Themen-Optionen

Mehrsprachiges Programm mit *ini

Ein Tutorial von Ashanita · begonnen am 23. Dez 2008 · letzter Beitrag vom 23. Nov 2017
Antwort Antwort
Seite 1 von 6  1 23     Letzte »    
Ashanita
Registriert seit: 29. Mai 2008
Zu allererst:

Ich hoffe etwas ähnliches wurde nicht schon früher gepostet, denn ich bin mit der Suchfunktion auf nichts gestoßen. Falls es ein ähnliches Tutorial schon geben sollte, dann verzeiht mir

Multilanguage Programm


by Whiteprince aka Ashaníta


Allgemeine Information

Zubereitungszeit: ca. 30-45 Minuten
Schwierigkeitsgrad: mittel
Freischaltung: 23. Dezember 08

Beschreibung

Das Programm soll mit mehreren Sprachen mit INI Konfiguration verfügbar sein, sprich wenn man als Einstellung ENGLISCH für das Programm wählt, wird das ganze Programm ins Englische übersetzt.

Screenshots & Demo Downloads

http://gpproductions.kilu.de/Multi-Language-TUT.bmp

Download usw.: SIEHE ANHANG!

Zutaten für 1 Programm:
  1. Button | Name: Deutsch (Name NICHT Caption!)
    Button | Name: Englisch
    Label | Name: TestLabel1
    Label | Name: TestLabel2
Vorbereitung

Erstelle ein neues Projekt (VCL-Formularanwendung) und ziehe alle oben aufgelisteten Komponenten auf die Form. (Genau ausrichten kann man die Später )

Zubereitung

Zuallererst: was hat welche Komponente für eine Aufgabe?

Deutsch (Button) | Übersetzt ganzes Programm in Deutsch
Englisch (Button) | Übersetzt ganzes Programm in Englisch
TestLabel1 (Label) | Einfacher Text zum überprüfen ob Übersetzung funktoniert
TestLabel2 (Label) | Selbe wie TestLabel1

Zuerst fügen wir (ganz wichtig!)IniLang in die uses rein!

Jetzt doppelklicken wir (in der Form) auf den Deutsch-Button. Jetzt können wir mit Hilfe der procedure Funktion bestimmen was beim Button-Klick passiert. Wir geben an, dass beim Klick das Programm übersetzt wird:

Code:
CL:=loadIni(DE) // DE steht hier für Deutsch
Und jetzt, dass ALLE Labels bzw Button (oder was auch immer) Captions mit den englischen/deutschen Wörtern gefüllt wird:

Delphi-Quellcode:
if CL<>nil then
begin
fillProps([form1],CL); // Alles füllen
Das sieht dann jetzt so aus:

Delphi-Quellcode:
procedure TForm1.DeutschClick(Sender: TObject);
begin
CL:=loadIni(DE);
if CL<>nil then
fillProps([form1],CL);
end;
Damit wir das ganze jetzt auch in Englisch machen können, doppelklicken wir auf den Englisch-Button und geben folgenden Code ein:

Delphi-Quellcode:
procedure TForm1.EnglischClick(Sender: TObject);
begin
CL:=loadIni(EN); // Statt DE steht jetzt hier EN
if CL<>nil then
fillProps([form1],CL);
end;
Jetzt erstellen wir die Labels.

Und nun erstellen wir 2 Ini-Dateien, eine mit dem Namen "Englisch.ini" und eine mit dem Namen "German.ini" (die Dateien müssen so heißen).

Die Englisch.ini füllen wir folgendermaßen:

Delphi-Quellcode:
[Form1]
Form1.Caption=Gewünschter Text für die Form-Caption in Englisch
Form1.Englisch.Caption=Gewünschter Text für den Englisch-Button in Englisch
Form1.Deutsch.Caption=Gewünschter Text für den Deutsch-Button in Englisch
Form1.TestLabel1.Caption=Gewünschter Text für den TestLabel1 in Englisch
Form1.TestLabel2.Caption=Gewünschter Text für den TestLabel2 in Englisch
Und die German.ini genau gleich ABER auf Deutsch

Damit das Programm gleich beim starten übersetzt wird, doppelklicken wir in die Form (FormCreate Funktion) und geben folgendes ein:

Delphi-Quellcode:
CL:=loadIni(DE); // DE wenn ihr Deutsch laden wollt und EN wenn ihr Englisch laden wollt
if CL<>nil then
fillProps([form1],CL);
Das sieht dann so aus:

Delphi-Quellcode:
procedure TForm1.FormCreate(Sender: TObject);
begin
CL:=loadIni(DE);
if CL<>nil then
fillProps([form1],CL);
end;
TEST

Jetzt Compilieren wir das ganze und starten das Programm (bitte geht sicher, dass German.ini und Englisch.ini im selben Ordner wie euer Programm ist) und klicken einmal auf den Englisch-Button bzw den Deutsch-Button und TADA es geht

[edit=Phoenix]Verlinkung auf Rapidshare entfernt. Wenn, dann bitte hier anhängen. Mfg, Phoenix[/edit]
Angehängte Dateien
Dateityp: zip multilanguagetutinilang_213.zip (4,9 KB, 77x aufgerufen)
Dateityp: rar multilanguagetutsource_182.rar (8,5 KB, 67x aufgerufen)
Dateityp: rar multilanguagetutdemo_983.rar (177,5 KB, 69x aufgerufen)

Geändert von mkinzler (30. Jul 2010 um 12:27 Uhr) Grund: Code-Tags durch Delphi-Tags ersetzt
 
Benutzerbild von DeddyH
DeddyH

 
Delphi 12 Athens
 
#2
  Alt 23. Dez 2008, 02:23
Hallo und Willkommen in der DP ,

Du hast Dir da viel Mühe gegeben, allerdings erscheint mir die Bedienung etwas umständlich (ohne es ausprobiert zu haben, ich habe nur Deinen Beitrag gelesen). Vielleicht möchtest Du einmal einen Blick auf sakuras Localizer werfen, um Dir ein paar weitere Anregungen zu holen.
Detlef
  Mit Zitat antworten Zitat
Cyf

 
Lazarus
 
#3
  Alt 23. Dez 2008, 02:28
Ich denke, es ist sinnvoller die Sprachen in DLLs auszulagern.
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

 
Delphi 12 Athens
 
#4
  Alt 23. Dez 2008, 02:32
Och, der Möglichkeiten gibt es viele, Ressourcen-DLLs sind eine davon (und IMHO keine schlechte).
Detlef
  Mit Zitat antworten Zitat
Benutzerbild von sx2008
sx2008

 
Delphi 2007 Professional
 
#5
  Alt 23. Dez 2008, 08:01
Zitat von Cyf:
Ich denke, es ist sinnvoller die Sprachen in DLLs auszulagern.
Es kommt darauf an.
Bei Freeware gibt es öfters User, die das Programm freiwillig in ihre eigene Sprache übersetzen wollen.
INI-Dateien sind einfach mit dem Editor zu bearbeiten.
Bei Resourcen-DLLs könnte die Hürde schon zu hoch sein.
  Mit Zitat antworten Zitat
Benutzerbild von Phoenix
Phoenix
 
#6
  Alt 23. Dez 2008, 08:22
Dafür gibt es aber z.B. Gnu/gettext auch für Delphi. Dort hat man standardisierte .pl-Files mit denen diese freiwilligen Helfer dann auch arbeiten können.

Ich würde auf jeden Fall mit ressourcen arbeiten. Da gibt es genug Automatisierung um angenehm zu arbeiten. Der Aufwand so etwas ausgereiftes von Hand nachprogrammieren zu wollen (zumal noch mit .ini-Dateien, die schon etwas.. in die Jahre gekommen sind) ist einfach nicht gerechtfertigt.
Sebastian Gingter
  Mit Zitat antworten Zitat
hoika

 
Delphi 10.4 Sydney
 
#7
  Alt 23. Dez 2008, 08:27
Hallo,

ausserdem sind Inis mit Vista nicht mehr so einfach zu benutzen.


Heiko
Heiko
  Mit Zitat antworten Zitat
Benutzerbild von Die Muhkuh
Die Muhkuh

 
Delphi 2009 Professional
 
#8
  Alt 23. Dez 2008, 08:53
Inwiefern?
Manuel
  Mit Zitat antworten Zitat
hoika

 
Delphi 10.4 Sydney
 
#9
  Alt 23. Dez 2008, 09:08
Hallo,

der Pfad der Inis wird "virtualisiert".
Da ins Programme-Verzeichnis nicth geschieben werden kann,
legt Vista die Ini selbständig im Nutzerverzeichnis (Pfad steht im Netz) ab,
und gaukelt dem Programm vor, dass die Ini erfolgreich im Programm-Verzeichnis geschieben wurde.

Das wird dann lustig, wenn man Änderungen im falschen Verzeuichnis sucht und nicht findet.

Heiko
Heiko
  Mit Zitat antworten Zitat
Benutzerbild von Die Muhkuh
Die Muhkuh

 
Delphi 2009 Professional
 
#10
  Alt 23. Dez 2008, 09:17
Das lustige daran ist, dass Du im Programm-Verzeichnis keinerlei Daten abzulegen hast und wenn man es macht, wie man es sollte, nämlich unter AppData, funktioniert alles ohne Probleme.
Manuel
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 6  1 23     Letzte »    


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:39 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