Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Multimedia (https://www.delphipraxis.net/16-multimedia/)
-   -   Delphi Dateigröße (voraus-)berechnen? (https://www.delphipraxis.net/32982-dateigroesse-voraus-berechnen.html)

Airblader 30. Okt 2004 23:48


Dateigröße (voraus-)berechnen?
 
Hi :)
Sorry, dass ich euch schon wieder nerven muss *g*

Folgendes:
Beim Speichern will ich per TrackBar die Kompression der zu speichernden (JPG)Datei ändern.
An sich kein Problem.
Da es um eine bestimmte Sorte Grafikn geht, wo die Anwender genau die Größe wissen müssen (frgat bitte nicht - es ist so ;) ), will ich "live" die kB größe anzeigen.

Nunja.
2 Ansätze:
----------

1. Datei temporär speichern, Größe lesen, löschen, Größe anzeigen.
Nachteil: SEHR langsam (speziell bei größeren Grafiken)

2. (Auf Tipp hin):
JPG-Algorithmus nehmen, verstehen und damit die Größe berechnen.
Nachteil: (Langsam? :gruebel: ) Man muss den Algortihmus erstmal verstehen *g* Ich hab ihn gesehen...und es ist :freak: :mrgreen:

--------------------------------------

Naja...Zusammengefasst:
Hat jemand eine Idee / einen Ansatz?

Wäre über Ideen o.ä. froh :)

Air

---
P.S.:
Kann man bei TrackBars den gestrichelten Kasten biem anklicken/markieren verhindern?

gmarts 31. Okt 2004 00:35

Re: Dateigröße (voraus-)berechnen?
 
Zitat:

Zitat von Airblader
Hi :)
1. Datei temporär speichern, Größe lesen, löschen, Größe anzeigen.
Nachteil: SEHR langsam (speziell bei größeren Grafiken)

2. (Auf Tipp hin):
JPG-Algorithmus nehmen, verstehen und damit die Größe berechnen.
Nachteil: (Langsam? :gruebel: ) Man muss den Algortihmus erstmal verstehen *g* Ich hab ihn gesehen...und es ist :freak: :mrgreen:

--------------------------------------

1. Genau so wirds gemacht. Alternativ kannst du auch nur zB. die Hälfe des Bildes nehmen und so auf die Zeit des ganzen Bildes schließen (Funktioniert nicht bei Bildern die in ihrer Komplexität varieren(z.B. Obere Hälfte Blauer Himmel, untere Hälfe Blumenfeld));

2. Wie gesagt; da Bildermotive unterschiedlich komplex sein können, kannst du es nicht genau vorausberechnen wie lange es dauert.


Edit: Ach..ich bin schon etwas müde. :freak: ...naja...dir gehts nicht um die Verschlüsslungszeit, sondern um die Größe.... Ist das gleiche in grün.

dizzy 31. Okt 2004 01:42

Re: Dateigröße (voraus-)berechnen?
 
Bin gerade dabei JPEG zu verstehen, und nachzuproggen. Leider ist das echt nicht einfach... aber es sei gesagt, dass es keinen Unterschied macht ob du den Algo verstehst oder nicht - du wirst eine Testdatei machen müssen (oder zumindest einen MemoryStream) um eine brauchbare Vorschau der Größe gebebn zu können. Zumindest die Cosinustransformation muss passieren - den Huffmann kann man sich u.U. dafür sogar sparen. Aber eine Schätz-Routine wird aller Wahrscheinlich nach deutlich langsamer sein als ein gut programmierter Huffmann - die DCT wird imho den Großteil der Zeit benötigen.
Die Größe der Datei hängt bei JPEG dermaßen stark vom Inhalt ab, dass es nahezu unmöglich ist die Größe zu bestimmen bevor man nicht in echt eine vollständige Kompression gemacht hat.
Evtl. sind hoch optimierte Schätz-Algos denkbar, aber wahrscheinlich mathematisch irrsinnig komplex, und dann u.U. auch nur bedingt bauchchbar.

Du könntest ja mal versuchen das Bild um einen Faktor zu verkleinern - mit verschiedenen Antialiasingmethoden am besten - und dann abschätzen wie die Größe des verkleinerten in Zusammenhang mit dem Original steht. Aber da solltest du mit allen möglich Varianten von Bildern testen: Eine einfarbige Bitmap, Fotos div. Motive, Zeichnungen, s/w-Rauschen, Farbrauschen etc.
Und mit verschiednen AA-Methoden, da das einen starken Einfluss auf die Komprimierbarkeit haben dürfte.

Fazit: Lass besser eine Testdatei erstellen ;)

Gruss,
Fabian

Chewie 31. Okt 2004 08:55

Re: Dateigröße (voraus-)berechnen?
 
Das Bild zu komprimieren wirst du wohl müssen, aber auf die Platte speichern muss dann nicht sein. Diese Zeit kannst du dir sparen, indem die Umwandlung nur im Speicher vornimmst. Auf heutigen Rechnern dürfte das auch nicht allzu lange dauern. Wenn das in einem Thread im Hintergrund abläuft, wird der Benutzer davon auch nicht gestört.

Airblader 31. Okt 2004 09:19

Re: Dateigröße (voraus-)berechnen?
 
Naja...ok...dann halt so :)

Nun...wie erstell ich die Datei nur temporär/im Speicher oder wie auch immer? *g*

Ich hab eben das gefunden:

Delphi-Quellcode:
function FileCreateTemp(var Prefix: string): THandle;
Ich hoffe, dass ich das nun der (englischen) Hilfe richtig entnommen habe:

Die ersten 3 Buchstaben des Speichernamens ergeben den temporären Dateinamen.
Wenn die Datei erstellt werden konnte, liefert die Funktion den THandle für die Datei.
Wenn ich mit der Datie fertig bin, kann ich sie mit CloseHandle() schliessen.

D.h., wenn ich habe:

Delphi-Quellcode:
FileCreateTemp('datei.jpg');
ist der Dateiname nur 'dat.jpg' ?
Und der THandle liefert mir ja den kompletten Pfad mit zurück.

D.h., um die Datei zu erstellen, müsste ich aber so vorgehen:

Delphi-Quellcode:
Assign(FormX.Image1.Picture.Bitmap);
FileCreateTemp('datei.jpg');
/Edit:
Hm...um darauf zuzugreifen, muss ich dann eine variable mit typ THandle haben und in diese dann die Funktion speichern?
Also so?:
Delphi-Quellcode:
var s: THandle;
...
Assign(FormX.Image1.Picture.Bitmap);
s := FileCreateTemp('datei.jpg');
Und dann ist 's' mein kompletter Handle?

/edit2:
Hm...was muss ich noch "usen", damit er FileCreateTemp kennt?
Im Moment gibt er mir undefin. Bez. :(

air


Alle Zeitangaben in WEZ +1. Es ist jetzt 05:50 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