![]() |
Sonderzeichen in TEdits (Charset?)
Liste der Anhänge anzeigen (Anzahl: 1)
Wir haben eine ältere Prä-Unicode-Anwendung, die mittlerweile auf D2007 portiert ist. In dieser kann der Anwender auswählen, welches Charset für TEdits verwendet wird. Wenn der Benutzer (auf einem deutschen System) z.B. Russisch auswählt und dann äöüÄÖÜß eintippt, sieht das im Edit wie im Anhang aus - soweit so gut. Jetzt versuche ich dieses Verhalten in einer "jungfräulichen" D2007-VCL-Anwendung nachzuvollziehen (Form1 mit einem Edit1 drauf) und kriege es nicht hin. Offensichtlich reicht ein
nicht aus. Habt ihr eine Idee, was ich da vergessen habe? Im Quelltext der Anwendung, wo es funktioniert, springt mir leider nichts einschlägiges ins Auge. |
AW: Sonderzeichen in TEdits (Charset?)
Bei meinem Delphi 5 funktioniert das auf Abhieb nur durch Umstellen von Font.Charset im Objektinspektor.
Natürlich muss dein Windows auch ClearType- oder Truetype-Fonts installiert haben, bei denen die russischen Zeichen enthalten sind. Die Codepage 1251 Cyrilic wird nicht von jedem Font unterstützt. |
AW: Sonderzeichen in TEdits (Charset?)
Zitat:
Kannst du bitte mal dein Projekt anhängen, am besten Quelltext + Exe, damit ich es mal auf meinem System laufen lassen kann? |
AW: Sonderzeichen in TEdits (Charset?)
Zitat:
Ohne den richtigen Font bist mit der Codepage ziemlich verloren. Gruß K-H |
AW: Sonderzeichen in TEdits (Charset?)
Zitat:
|
AW: Sonderzeichen in TEdits (Charset?)
Liste der Anhänge anzeigen (Anzahl: 1)
Demo-Programm im Anhang.
Courier New unterstützt die Codepages auf meinem System (Windows XP SP3). |
AW: Sonderzeichen in TEdits (Charset?)
Zitat:
Ich hab's jetzt rausgefunden - es ist das Theming. :wall: Ein XPMan ins uses deines Testprogramms und bumm - nix mehr Kyrillisch. :roll: Na, mal schauen, ob man da was machen kann... Update: Ich bin nicht der Einzige mit dem Problem: Eine Lösung habe ich aber noch nicht gefunden. |
AW: Sonderzeichen in TEdits (Charset?)
Wenn du kein Win9x/ME benötigst nimm die letzte freie Version der TNTWare-Kompos (oder die neuen von TMS) und schmeiß die Codepage/Charset-Krücke weg.
|
AW: Sonderzeichen in TEdits (Charset?)
Zitat:
Delphi-Quellcode:
Das ist ja wohl verlustbehaftet. Kann mas das TNT-Edit irgendwie veranlassen, nur "passende" Eingaben zuzulassen? Und wenn wir schon dabei sind: Wie wäre das mit einem Unicode-VCL-TEdit?
type
TMyStoredRecord = record EinString: string[50]; end; var rec: TMyStoredRecord; begin rec.EinString := TntEdit1.Text; ... |
AW: Sonderzeichen in TEdits (Charset?)
Der Inhalt solcher Komponenten ist dann WideString.
|
AW: Sonderzeichen in TEdits (Charset?)
Zitat:
Zitat:
Also auf einem russischen System wird nur der rusische Teil in ANSI gespeichert. Ließt man nun diesen AnsiString in einem anderem System aus, so wird da ebenfalls die SystemCodePage verwendet und es wird falsch ausgelesen. Also lieber WideString nutzen, oder
Delphi-Quellcode:
TMyStoredRecord = record
EinString: array[1..50] of WideChar; end; |
AW: Sonderzeichen in TEdits (Charset?)
Zitat:
Zitat:
|
AW: Sonderzeichen in TEdits (Charset?)
Da D2007 Recordoperatoren bietet, könnte man für das WideChar-Array einen Ersatz stellen, welcher 100%ig wie ein WideString nutzbar ist und zugleich die Vorteile des ShortString/CharArray bietet.
![]() Gut, bei gespeicherten Records müßte man die Dateien/Recorddaten erstmal konvertieren. |
AW: Sonderzeichen in TEdits (Charset?)
Zitat:
Delphi-Quellcode:
genommen, aber das geht schon mal gar nicht. Als Notbehelf dachte ich an
FixedSizeUnicodeString<N: Integer>
Delphi-Quellcode:
, den ich z.B. als
FixedSizeUnicodeString<BaseT>
Delphi-Quellcode:
o.ä. instantiiert hätte, aber auch da ging nix. Habt ihr da schon mal eine funktionierende Lösung gesehen?
var s50: FixedSizeUnicodeString<string[50]>
|
AW: Sonderzeichen in TEdits (Charset?)
Nee, leider gibt es keine Möglichkeit, um bei den Generics Nummern zu übergeben.
Und wenn man den Speicher als
Delphi-Quellcode:
oder
String[x]
Delphi-Quellcode:
als Parameter übergibt, dann kann man nicht innerhalb des generischen Typs darauf zugreifen, um die nötigen Konvertierungen für die Operatoren zu implementieren.
array[0..x] of Char
Praktisch sind die Generics dafür komplett nutzlos. :evil: Von der Sprache/Syntax her wäre es schon möglich den Generigs etwas von Makros mitzugeben oder eben, daß man nicht nur Typen, sondern auch Werte (Nummern oder Strings) als "Parameter" an den Generic übergibt ... aber ob Emba jemals sowas Cooles in die Generics einbaut? (wäre immerhin ein Pluspunkt gegenüber den anderen Programmiersprachen, welche Generics kennen) Der Einzige Ausweg blieb halt nur noch ein "blödes" Template, über welches man sich zumindestens passende Typen basteln könnte. Da die Generics nur einmal geparst und sofort auf Syntax und Typverträglichkeit geprüft werden, wo der ersetzende Typ noch nichtmal bekannt ist, kann man da innerhalb der Generics leider nicht viel machen. :cry: Ein mehrschichtiger Parser würde mir in Delphi wirklich gefallen, welcher die Typkompatibilität erst nach dem Ersetzen der generischen Typen prüft. |
AW: Sonderzeichen in TEdits (Charset?)
Zitat:
Delphi-Quellcode:
, was sich zumindest compilieren ließ. :mrgreen: Aber leider war cBaseSize immer 0, egal, welchen Typ man übergeben hat. Experimente mit constraints (z.B.
FixedSizeUnicodeString<BaseT> = record
public const cBaseSize = SizeOf(BaseT); strict private FBuffer: array[0..Pred(cBaseSize)] of WideChar; end;
Delphi-Quellcode:
) haben das - WIMRE - behoben, sich aber nie für BaseT = string[N] compilieren lassen.
FixedSizeUnicodeString<BaseT: record>
Zitat:
Zitat:
![]() |
AW: Sonderzeichen in TEdits (Charset?)
Zitat:
Das Problem ist halt, daß BaseT zur Compilezeit und an dieser Stelle noch nicht bekannt ist. Leider arbeitet der Compiler nur in einem Durchgang, so daß der Code nicht nochmal übersetzt wird ... SizeOf bekommt also niemals den Ersatztypen mit, welchen man bei einer späteren Verwendung des GenTyps angibt. Leider fehlt mir auch die Zeit, um mich mal mit einem Precompiler für Delphi zu beschäftigen und zu schauen, ob sich da etwas machen ließe. :? (hatte zwar mal einen PreCompiler für D2005 oder 2006 gefunden, aber wenn ich jetzt suche, dann finde ich nur noch Welche für die alten Compiler ala D7 und das funktioniert unter neueren Delphis nicht mehr und ist meistens auch "unschön" gelöst) |
AW: Sonderzeichen in TEdits (Charset?)
Zitat:
Delphi-Quellcode:
Dann hatten Instantiierungen von FixedSizeUnicodeString zumindest die richtige SizeOf. Dafür hat's dann wieder woanders gehakelt, mal abgesehen davon, dass das eine Move/FillChar/Cast/Pointerarithmetik-Orgie geworden wäre.
FixedSizeUnicodeString<BaseT> = record
strict private FBufferPart1: T; FBufferPart2: T; end; Aus irgendeinem Grund verrät der Compiler uns aber die Größe nicht, auch wenn er sie kennt.:evil: |
Alle Zeitangaben in WEZ +1. Es ist jetzt 10:27 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