php小編魚仔您好!在golang中,如果您想知道圖像的當前品質並減小檔案大小,可以使用image/jpeg套件中的DecodeConfig函數來獲取圖像的基本信息,包括圖像的寬度、高度和顏色模式等。然後,您可以使用image套件中的Resize函數來調整影像的尺寸,從而減少檔案大小。此外,您也可以使用image/jpeg套件中的Options結構體來設定影像的品質參數,透過調整品質參數的值來進一步減少檔案大小。希望這個簡短的回答對您有幫助!
我正在嘗試減少/壓縮 golang 中圖像的檔案大小。當我使用 jpeg.Encode 並將選項作為品質 75 的參數傳遞時,10mb 的圖像變成了 18mb 的圖像......我不明白為什麼,這就是這個庫中的品質概念?
此外,我想知道在編碼之前如何知道哪個是原始質量,我想如果我知道我可以將其設置為較小的值,或者嘗試其他方法,例如將圖像大小調整為高度和寬度的10 %。
我希望了解 jpeg.Encode 函數中選項參數的品質屬性的標準。我想獲得更多有關圖像文件大小以及如何減小圖像文件大小的知識。
JPEG品質參數不是影像的特徵,而是JPEG編碼過程的特徵。由於 JPEG 是一種有損編碼,這意味著編碼影像無法解碼為準確的原始影像,因此您可以向編碼器指定它應如何忠實地嘗試複製原始影像。質量 100 應該幾乎沒有損失,品質較低的編碼器不會那麼努力。因此,品質參數越大,檔案大小越大,因為編碼器試圖保留更多資訊。 ]
為了直觀地理解為什麼編碼檔案最終可能比原始檔案大,以下是人類語音中「壓縮」的範例(不是 JPEG,但從資訊理論的角度來看,適用相同的原則):
000000000000000000000000000000000000000000000000
可以描述為“五十個零”,即 50:12 比例的壓縮(即原始碼長度減少了四倍以上)。
01101
是“一個零,兩個一,一個零和一個一”,5:34比例壓縮失敗,編碼值幾乎是原來的七倍。
這張照片(來自 JPEG 上的維基百科頁面)顯示了品質參數對結果影像,從左側的 0 到右側的 100:
如果不嘗試對圖像進行編碼,編碼器就無法知道結果是什麼;這很大程度上取決於圖像。 JPEG 非常擅長編碼顏色漸變,但非常擅長編碼銳利邊緣。因此,它可以很好地壓縮照片,但在壓縮照片等方面會非常糟糕。靜態噪音。
這意味著不存在“編碼前的原始品質”,除非您的影像已經進行了 JPEG 編碼。如果影像已經是JPEG 編碼的,並且您嘗試對其進行重新編碼,則通常會發現尺寸的增加幾乎沒有任何增益(因為編碼器不僅嘗試複製影像,還嘗試複製先前的影像)編碼),就像您嘗試壓縮已經壓縮的檔案一樣。對已經以其他方式編碼的圖像進行轉碼可能會也可能不會導致檔案大小減小,這取決於圖像和先前使用的編碼。
以上是如何知道golang中圖像當前的'品質”?我需要減小文件大小的詳細內容。更多資訊請關注PHP中文網其他相關文章!