Rumah > Artikel > pembangunan bahagian belakang > Bagaimana untuk mengetahui "kualiti" semasa imej dalam golang? Saya perlu mengecilkan saiz fail
php hello editor fishboy! Dalam golang, jika anda ingin mengetahui kualiti semasa imej dan mengurangkan saiz fail, anda boleh menggunakan fungsi DecodeConfig dalam pakej imej/jpeg untuk mendapatkan maklumat asas imej, termasuk mod lebar, ketinggian dan warna bagi imej, dsb. Anda kemudiannya boleh menggunakan fungsi Saiz semula daripada pakej imej untuk mengubah saiz imej, sekali gus mengurangkan saiz fail. Selain itu, anda juga boleh menggunakan struktur Pilihan dalam pakej imej/jpeg untuk menetapkan parameter kualiti imej, dan seterusnya mengurangkan saiz fail dengan melaraskan nilai parameter kualiti. Harap jawapan ringkas ini membantu!
Saya cuba kecilkan/mampatkan saiz fail imej dalam golang. Apabila saya menggunakan jpeg.Encode dan lulus pilihan sebagai hujah untuk kualiti 75, imej 10mb menjadi imej 18mb...Saya tidak faham mengapa, adakah ini konsep kualiti dalam perpustakaan ini?
Selain itu, saya ingin tahu cara mengetahui kualiti asal sebelum pengekodan, saya rasa jika saya tahu saya boleh menetapkannya kepada nilai yang lebih kecil, atau cuba sesuatu yang lain seperti mengubah saiz imej kepada 10% daripada ketinggian dan lebar.
Saya ingin mengetahui kriteria untuk atribut kualiti parameter pilihan dalam fungsi jpeg.Encode. Saya ingin mendapatkan lebih banyak pengetahuan tentang saiz fail imej dan cara mengurangkan saiz fail imej.
Parameter kualiti JPEG bukanlah ciri imej, tetapi ciri proses pengekodan JPEG. Memandangkan JPEG ialah pengekodan lossy, bermakna imej yang dikodkan tidak boleh dinyahkodkan kepada imej asal yang tepat, anda boleh menentukan kepada pengekod sejauh mana ia harus cuba mereplikasi imej asal. Kualiti 100 sepatutnya mengalami sedikit kerugian, pengekod kualiti yang lebih rendah tidak akan berfungsi sekuat mana. Oleh itu, lebih besar parameter kualiti, lebih besar saiz fail kerana pengekod cuba untuk mengekalkan lebih banyak maklumat. ]
Untuk memahami secara intuitif mengapa fail yang dikodkan mungkin menjadi lebih besar daripada fail asal, berikut ialah contoh "mampatan" dalam pertuturan manusia (bukan JPEG, tetapi dari perspektif teori maklumat, prinsip yang sama digunakan):
000000000000000000000000000000000000000000000000000
boleh digambarkan sebagai "lima puluh sifar", iaitu mampatan nisbah 50:12 (iaitu panjang kod sumber dikurangkan lebih daripada empat kali ganda).
01101
ialah "satu sifar, dua satu, satu sifar dan satu satu", mampatan nisbah 5:34 gagal dan nilai yang dikodkan hampir tujuh kali ganda daripada asal.
Foto ini (dari halaman Wikipedia pada JPEG) menunjukkan parameter kualiti berbanding imej yang terhasil, daripada 0 di sebelah kiri hingga 100 di sebelah kanan:
Pengekod tidak mempunyai cara untuk mengetahui keputusannya tanpa cuba mengekod imej itu; JPEG sangat baik dalam pengekodan kecerunan warna, tetapi sangat baik dalam pengekodan tepi tajam. Jadi ia boleh memampatkan foto dengan sangat baik, tetapi ia boleh menjadi sangat teruk dalam memampatkan foto dan sebagainya. bunyi statik.
Ini bermakna tiada "kualiti asal sebelum pengekodan" melainkan imej anda telah dikodkan JPEG. Jika imej sudah dikodkan JPEG dan anda cuba mengekodnya semula, anda biasanya akan mendapati sedikit atau tiada keuntungan dalam saiz (kerana pengekod bukan sahaja cuba menyalin imej, tetapi juga imej yang dikodkan sebelum ini), seperti anda Sama seperti cuba memampatkan fail yang sudah dimampatkan. Transkod imej yang telah dikodkan mungkin atau mungkin tidak menghasilkan saiz fail yang lebih kecil, bergantung pada imej dan pengekodan yang digunakan sebelum ini.
Atas ialah kandungan terperinci Bagaimana untuk mengetahui "kualiti" semasa imej dalam golang? Saya perlu mengecilkan saiz fail. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!