AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Bilder in DBasetabelle speichern
Thema durchsuchen
Ansicht
Themen-Optionen

Bilder in DBasetabelle speichern

Ein Thema von Fritz01 · begonnen am 10. Apr 2006 · letzter Beitrag vom 15. Jun 2007
Antwort Antwort
Fritz01

Registriert seit: 22. Mär 2006
Ort: Großenkneten
181 Beiträge
 
Delphi 7 Professional
 
#1

Bilder in DBasetabelle speichern

  Alt 10. Apr 2006, 09:36
Datenbank: DBase für Windows • Zugriff über: TTable
Hallo,
zu diesem Thema ist bereits sehr viel geschrieben, habe nichts passende gefunden.
Problem: Ein Bild 'TImage' soll in einer DBasetabelle mit einem Blobfeld 'Bild' abgelegt werden.
Hört sich ja ganz einfach an:
TImage.Picture.SaveToFile('Ort');
Wie aber bitte beschreibe ich ('Ort'), habe da schon so einiges erfoglos probiert. Wäre super eine passende Lösung zu erhalten.
Fritz
  Mit Zitat antworten Zitat
Benutzerbild von Union
Union

Registriert seit: 18. Mär 2004
Ort: Luxembourg
3.487 Beiträge
 
Delphi 7 Enterprise
 
#2

Re: Bilder in DBasetabelle speichern

  Alt 10. Apr 2006, 09:41
TImage.Picture.SaveToFile('Ort') schreibt das Bild in eine Datei auf der Festplatte. Du solltest mal unter Delphi-Referenz durchsuchenCreateBlobStream suchen.
Ibi fas ubi proxima merces
sudo /Developer/Library/uninstall-devtools --mode=all
  Mit Zitat antworten Zitat
Fritz01

Registriert seit: 22. Mär 2006
Ort: Großenkneten
181 Beiträge
 
Delphi 7 Professional
 
#3

Re: Bilder in DBasetabelle speichern

  Alt 10. Apr 2006, 19:09
Hallo,

hatte doch etwas mehr als nur einen Lesetipp erhofft! Gelesen habe ich da schon so einiges, habe dennoch meine kleinen oder große Problemchen.
Vielleicht gibt es da jemanden, der mir weiterhelfen kann.
Mein Problem wie schon beschrieben: TImage oder TDBImage --> TTable --> Feld 'Bild'
Fritz01
Fritz
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.851 Beiträge
 
Delphi 11 Alexandria
 
#4

Re: Bilder in DBasetabelle speichern

  Alt 10. Apr 2006, 19:31
Hallo Fritz01,
schau dir mal diesen Thread an, müßte hilfreich sein.
Markus Kinzler
  Mit Zitat antworten Zitat
marabu

Registriert seit: 6. Apr 2005
10.109 Beiträge
 
#5

Re: Bilder in DBasetabelle speichern

  Alt 10. Apr 2006, 20:29
Hallo Fritz,

am Ende läuft alles auf eine Zeile hinaus:

Delphi-Quellcode:
var
  bild: TBlobField;
  image: TImage;
begin
  with bild do
  begin
    DataSet.Edit;
    Assign(image.Picture); // <-- the very line
    DataSet.Post;
  end;
end;
Vielleicht kannst du ja meine angehängte Demo auch mit D4 lesen.

Freundliche Grüße vom marabu
Angehängte Dateien
Dateityp: zip blobdemo_809.zip (2,2 KB, 15x aufgerufen)
  Mit Zitat antworten Zitat
Fritz01

Registriert seit: 22. Mär 2006
Ort: Großenkneten
181 Beiträge
 
Delphi 7 Professional
 
#6

Re: Bilder in DBasetabelle speichern

  Alt 11. Apr 2006, 11:50
Hallo Marabu,
die Demo konnte ich nicht direkt lesen, konnte aber rekonstruieren.
Das war wirklich eine sehr gute Hilfe, und ich sage Dir dafür ein ganz großes DANKESCHÖN!!
Es hat nicht nur geholfen, es war die Lösung.
Fritz
Fritz
  Mit Zitat antworten Zitat
Seto

Registriert seit: 9. Jun 2007
9 Beiträge
 
#7

Re: Bilder in DBasetabelle speichern

  Alt 15. Jun 2007, 13:23
Hallo,

der Thread ist zwar schon alt aber ich hoffe trotzdem, dass ich noch eine Antwort bekomme. Ich habe mir auch die Demo runtergeladen und das ganze auf mein Projekt übertragen. Ich habe eine Datenbank mit einem Feld "Bild" als ftGraphic und möchte es genauso eintragen wie in der Demo. Ins Image laden funktioniert einwandfrei, das speichern auch. Allerdings erhalte ich eine Fehlermeldung, wenn ich das Bild dem Datensatz zuweisen möchte (in der Demo ist das der "Write" Button).

Die Fehlermeldung lautet "Pfad nicht gefunden. Tabelle C:.\db\artikel.Mb. Der Prozess wurde angehalten". Meine Datenbank Dateien befinden sich in einem Unterordner /db im Projektverzeichnis, habe also bei Databasename in der Tablekomponente .\db eingetragen und in dem Ordner befindet sich auch die Datei, die er angeblich nicht findet. Weiß jemand eine Lösung zu dem Problem?

/edit: In dem Zusammenhang noch eine Frage, ist es möglich, das Feld "Bild" in dem ja eigentlich nichts sinnvolles angezeigt, sondern nur eingetragen wird per Feld-Editor auszublenden? Werden die Bilder dann trotzdem noch angezeigt? Ich kann es ja momentan nicht testen, da ich immer obrige Fehlermeldung erhalte.

Freundliche Grüße, Seto
  Mit Zitat antworten Zitat
marabu

Registriert seit: 6. Apr 2005
10.109 Beiträge
 
#8

Re: Bilder in DBasetabelle speichern

  Alt 15. Jun 2007, 16:34
Hallo Seto,

wenn der Write-Button nicht funktioniert, dann dürfte auch der Read-Button nicht funktionieren. Um zu vermeiden, dass ein falsches DB-Verzeichnis verwendet wird solltest du die Eigenschaft Table.Active im Object Inspector auf False setzen und im Code das Ereignis OnCreate() der Form einfügen:

Delphi-Quellcode:
procedure TDemoForm.FormCreate(Sender: TObject);
var
  fn: TFileName;
begin
  Table.DatabaseName := ExtractFilePath(ParamStr(0)) + 'db';
  fn := IncludeTrailingPathDelimiter(Table.DatabaseName) + Table.TableName + '.db';
  if FileExists(fn)
    then Table.Open
    else ShowMessage(Format('Datei nicht gefunden:%s%s', [sLineBreak, fn]));
end;
So wird das Unterverzeichnis DB des Programmverzeichnisses als DB-Verzeichnis verwendet und du erhältst eine Fehlermeldung, wenn die Tabelle nicht existiert.

Um die Spaltenanzeige zu konfigurieren kannst du über das Kontextmenü des DBGrid den Spalteneditor öffnen und dir die gewünschten Spalten selbst zusammenstellen.

Freundliche Grüße
  Mit Zitat antworten Zitat
Seto

Registriert seit: 9. Jun 2007
9 Beiträge
 
#9

Re: Bilder in DBasetabelle speichern

  Alt 15. Jun 2007, 17:53
Vielen Dank für die schnelle Antwort! Also der Read Button hat seltsamerweise einwandfrei funktioniert, zumindest ohne Fehlermeldung, diese kam nur beim Write Button.
So seltsam es sich anhört, das Problem hat sich von selbst gelöst. Ich hab zwar vorhin beim Testen Delphi auch neugestartet aber da kam die Meldung weiterhin. Ich habe erst mal an anderen Teilen im Programm weitergebastelt und dann gings plötzlich.
Werds aber sicherheitshalber noch so machen wie du empfohlen hast.

Viele Grüße
  Mit Zitat antworten Zitat
marabu

Registriert seit: 6. Apr 2005
10.109 Beiträge
 
#10

Re: Bilder in DBasetabelle speichern

  Alt 15. Jun 2007, 17:59
Wenn du beim Testen einer BDE-Anwendung aus der IDE heraus Laufzeitfehler produzierst, die von dir nicht über eine Exception abgefangen werden, dann solltest du grundsätzlich die Delphi-IDE neu starten bevor du weiter arbeitest. Ansonsten können Fehler auftreten, die kaum zu erklären sind.

Freundliche Grüße
  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 14:21 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