DevExpress Grid: Filter mit Sonderzeichen
Moin!
Meine User lieben im TcxGrid die Filterrow und verwenden sie auch sehr fleißig. Nun habe ich leider recht viele Datensätze mit Sonderzeichen drin, die in Deutschland nicht üblich sind. Beispiele wäre "Ł" oder "ą" Diese Zeichen sollen nun beim Filtern wie "L" oder "a" behandelt werden. Beim Sortieren kann man dies durch die Option DataController.Options := [dcoAnsiSort] erreichen. Aber leider gibt eine solche Option beim Filtern nicht. Wie kann ich das erreichen, dass die Sonderzeichen entsprechend behandelt werden? Danke! |
AW: DevExpress Grid: Filter mit Sonderzeichen
Hat niemand eine Idee dazu? :cry:
|
AW: DevExpress Grid: Filter mit Sonderzeichen
Der DataControler im Grid besitzt entsprechende Events, welche du da bestimmt benutzen könntest.
cxGrid.DataController.OnCompare cxGrid.DataController.OnFilterRecord cxGrid.DataController.Filter.OnFormatFilterTextValue ... k.A. was fcoSoftCompare für eine Option ist, da die Hilfe das grade nicht verraten will. |
AW: DevExpress Grid: Filter mit Sonderzeichen
Zitat:
Zitat:
Zitat:
|
AW: DevExpress Grid: Filter mit Sonderzeichen
Mit dem RecordIndex kannst du dir den Record (Datensatz) aus dem DataController holen und dann die Filterung selber implementieren.
In deinem Fall müsstest du auch noch die Filter auslesen, damit du weißt, was dort verglichen werden muß. Alternativ leitet man den DataController ab (vorher natürlich den GridView und eventuell auch das Grid), da drin wird dann die Filterklasse ersetzt (es gibt dort irgendwo eine GetFilterClass-Funktion) und nachdem man die Filter-Vergleichs-Funktion in den wirren Tiefen des Quellcodes gefunden hat, kann man diese überschreiben (override). :angle2: |
AW: DevExpress Grid: Filter mit Sonderzeichen
Das Wichtigste wäre ja mal eine Umsetzungstabelle für diese Codes. "Ł" oder "ą" sind eben kein "L" oder "a". Also musst Du sowohl die Daten als auch die Eingaben erst einmal "normalisieren".
|
AW: DevExpress Grid: Filter mit Sonderzeichen
Das ist jetzt meine Naja-Lösung. Ich hab mir eine Function auf dem Datenbankserver gemacht, die die Zeichen ersetzt, also den String normalisiert. So kann ich die Daten gleich normalisiert im Grid anzeigen lassen.
Das ist jetzt aber nicht wirklich eine schöne Lösung, da ja dann die Daten im Grid eigentlich verfälscht sind. In meinem Fall kann ich damit leben, wirklich schön finde ich es jedoch nicht. |
AW: DevExpress Grid: Filter mit Sonderzeichen
Du könntest es doch auch erst im DisplayValue normalisieren?
Im EditMode würde man es dann notfalls wieder richtig sehen können. @Union: Das Umwandeln kann man sich von Windows machen lassen. z.B. siehe WideCharToMultiByte WC_NO_BEST_FIT_CHARS |
AW: DevExpress Grid: Filter mit Sonderzeichen
Zitat:
|
AW: DevExpress Grid: Filter mit Sonderzeichen
Konnte man das nicht irgendwo umstellen, also was er nimmt?
|
Alle Zeitangaben in WEZ +1. Es ist jetzt 17:42 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