AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Code-Bibliothek Library: Datenbanken Delphi Binäre Datenfelder im DBGrid anzeigen/bearbeiten
Thema durchsuchen
Ansicht
Themen-Optionen

Binäre Datenfelder im DBGrid anzeigen/bearbeiten

Ein Thema von shmia · begonnen am 7. Feb 2005
Antwort Antwort
shmia

Registriert seit: 2. Mär 2004
5.508 Beiträge
 
Delphi 5 Professional
 
#1

Binäre Datenfelder im DBGrid anzeigen/bearbeiten

  Alt 7. Feb 2005, 12:28
Datenfelder mit binären Daten werden in einem DBGrid ja nur als
(VarBytes) oder (VARBYTES) angezeigt. (je nachdem ob das Feld einen Inhalt hat oder nicht)

Dieses Verhalten lässt sich ändern, wenn man für die Felder einen Eventhandler für OnGetText und OnSetText bereitstellt.
Delphi-Quellcode:
procedure TForm1.BinaryFieldOnGetText(Sender: TField; var Text: String; DisplayText: Boolean);
begin
  if Assigned(Sender) then
  begin
    if DisplayText then
      Text := '0x'+StrToHexString(Sender.AsString)
    else
      Text := StrToHexString(Sender.AsString);
  end;
end;

procedure TForm1.BinaryFieldOnSetText(Sender: TField; const Text: String);
begin
  if Assigned(Sender) then
    Sender.AsString := HexStringToStr(Text);
end;
Nun muss man natürlich dafür sorgen, dass alle binären Felder mit diesem Eventhandler ausgestattet werden:
Delphi-Quellcode:
// neue Eventhandler zuweisen
procedure TForm1.ADOQuery1AfterOpen(DataSet: TDataSet);
var
  i : Integer;
begin
  // Schleife über alle Felder; rückwärts ist schneller
  for i := DataSet.FieldCount-1 downto 0 do
  begin
    if DataSet.Fields[i].DataType in [ftBytes, ftVarBytes] then
    begin
       DataSet.Fields[i].OnGetText := BinaryFieldOnGetText;
       DataSet.Fields[i].OnSetText := BinaryFieldOnSetText;
    end;
  end;
end;
Die beiden Hilfsfunktionen StrToHexString und HexStringToStr findet man in der Code-Library:
http://www.delphipraxis.net/internal...ct.php?t=46356

[edit=Matze]Code formatiert. Mfg, Matze[/edit]
Andreas
  Mit Zitat antworten Zitat
Antwort Antwort

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 06:13 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