Heim > Artikel > Backend-Entwicklung > Wie erkennt man die aktuelle „Qualität' eines Bildes in Golang? Ich muss die Dateigröße reduzieren
php Hallo Herausgeber, Fishboy! Wenn Sie in Golang die aktuelle Qualität eines Bildes wissen und die Dateigröße reduzieren möchten, können Sie die Funktion DecodeConfig im Paket image/jpeg verwenden, um die grundlegenden Informationen des Bildes abzurufen, einschließlich Breite, Höhe und Farbmodus das Bild usw. Anschließend können Sie die Funktion „Größe ändern“ aus dem Bildpaket verwenden, um die Größe des Bildes zu ändern und so die Dateigröße zu reduzieren. Darüber hinaus können Sie auch die Optionsstruktur im Paket image/jpeg verwenden, um die Qualitätsparameter des Bildes festzulegen und die Dateigröße weiter zu reduzieren, indem Sie den Wert der Qualitätsparameter anpassen. Ich hoffe, diese kurze Antwort hilft!
Ich versuche, die Dateigröße von Bildern in Golang zu reduzieren/komprimieren. Wenn ich jpeg.Encode verwende und die Option als Argument für Qualität 75 übergebe, wird aus dem 10-MB-Bild ein 18-MB-Bild ... Ich verstehe nicht warum, ist das das Qualitätskonzept in dieser Bibliothek?
Außerdem würde ich gerne wissen, wie ich vor dem Codieren die Originalqualität ermitteln kann. Wenn ich das weiß, kann ich sie auf einen kleineren Wert einstellen oder etwas anderes versuchen, wie z. B. die Größenänderung des Bildes auf 10 % der Höhe und Breite.
Ich würde gerne die Kriterien für das Qualitätsattribut des Optionsparameters in der jpeg.Encode-Funktion wissen. Ich würde gerne mehr über die Größe von Bilddateien und die Reduzierung der Bilddateigröße erfahren.
JPEG-Qualitätsparameter sind kein Merkmal des Bildes, sondern ein Merkmal des JPEG-Kodierungsprozesses. Da es sich bei JPEG um eine verlustbehaftete Kodierung handelt, d. Bei Qualität 100 sollte es kaum zu Verlusten kommen, Encoder mit niedrigerer Qualität werden nicht so hart arbeiten. Je größer der Qualitätsparameter ist, desto größer ist daher die Dateigröße, da der Encoder versucht, mehr Informationen zu behalten. ]
Um intuitiv zu verstehen, warum die codierte Datei möglicherweise größer als die Originaldatei ist, finden Sie hier ein Beispiel für „Komprimierung“ in der menschlichen Sprache (nicht JPEG, aber aus informationstheoretischer Sicht gelten dieselben Prinzipien):
000000000000000000000000000000000000000000000000000
kann als „fünfzig Nullen“ beschrieben werden, eine Komprimierung im Verhältnis 50:12 (d. h. die Länge des Quellcodes wird um mehr als das Vierfache reduziert).
01101
ist „eins Null, zwei Einsen, eins Null und eins Eins“, die Komprimierung im Verhältnis 5:34 schlägt fehl und der codierte Wert ist fast siebenmal so groß wie das Original.
Dieses Foto (von der Wikipedia-Seite auf JPEG) zeigt die Qualitätsparameter im Vergleich zum resultierenden Bild, von 0 links bis 100 rechts:
Der Encoder kann nicht wissen, wie das Ergebnis aussehen wird, ohne zu versuchen, das Bild zu kodieren; es hängt stark vom Bild ab. JPEG ist sehr gut bei der Kodierung von Farbverläufen, aber sehr gut bei der Kodierung scharfer Kanten. Die Komprimierung von Fotos ist also sehr gut, die Komprimierung von Fotos usw. jedoch sehr schlecht. statisches Rauschen.
Das bedeutet, dass es keine „Originalqualität vor der Kodierung“ gibt, es sei denn, Ihr Bild wurde JPEG-kodiert. Wenn das Bild bereits JPEG-kodiert ist und Sie versuchen, es neu zu kodieren, werden Sie wie Sie in der Regel kaum oder gar keinen Größengewinn feststellen (da der Kodierer nicht nur versucht, das Bild, sondern auch das zuvor kodierte Bild zu kopieren). Dies entspricht dem Versuch, eine bereits komprimierte Datei zu komprimieren. Das Transkodieren eines Bildes, das anderweitig kodiert wurde, kann je nach Bild und zuvor verwendeter Kodierung zu einer verringerten Dateigröße führen oder auch nicht.
Das obige ist der detaillierte Inhalt vonWie erkennt man die aktuelle „Qualität' eines Bildes in Golang? Ich muss die Dateigröße reduzieren. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!