Categories: JavascriptTips Trik

compress gambar sebelum diupload dengan javascript

Bismillaahirrohmaanirrohiim…

Berikut ini cara kompress gambar sebelum diupload menggunakan javascript, tujuannya agar misalkan gambar dari HP yang ukurannya besar ini menjadi ringan saat upload.

Nah beginilah script kodenya:

<div class="mb-3">
                        <div class="" style="font-weight: 500;margin-bottom: .5rem;">Upload Foto/Video/File</div>
                        <div class="row" id="file_timeline_wrapper">
                            <div class="col-md-6 tr_file_timeline mb-2">
                                <table>
                                    <tr>
                                        <td style="width:30px;text-align: left;">
                                            <i class="bi bi-x-circle-fill" style="font-size: 150%;cursor: pointer;color: red;" >



Kode javascriptnya:

$(document).on("change", ".file_timeline", async function(e) {
    let id_tl = $(this).attr("id");
    

    const file = e.target.files[0];
    if (!file) return;
    if (!file.type.startsWith(\'image/\')) return;

    $("#originalInfo").text(`Ukuran file: ${(file.size / 1024).toFixed(2)} KB`);

    // kompres gambar
    const compressed = await compressImage(file, 0.7, 800, 800);
    const compressedUrl = URL.createObjectURL(compressed);

    $("#imagePreview").attr("src", compressedUrl).removeClass("d-none");
    $("#compressedInfo").text(` => compressed: ${(compressed.size / 1024).toFixed(2)} KB`);

    // Ganti isi input file dengan file hasil kompres
    const dataTransfer = new DataTransfer();
    dataTransfer.items.add(compressed);
    document.getElementById(id_tl).files = dataTransfer.files;
});
async function compressImage(file, quality = 0.7, maxWidth = 1000, maxHeight = 1000) {
      return new Promise((resolve, reject) => {
        const reader = new FileReader();
        reader.readAsDataURL(file);
        reader.onload = event => {
          const img = new Image();
          img.src = event.target.result;
          img.onload = () => {
            // hitung rasio baru
            let width = img.width;
            let height = img.height;

            if (width > maxWidth || height > maxHeight) {
              const ratio = Math.min(maxWidth / width, maxHeight / height);
              width *= ratio;
              height *= ratio;
            }

            const canvas = document.createElement(\'canvas\');
            const ctx = canvas.getContext(\'2d\');
            canvas.width = width;
            canvas.height = height;
            ctx.drawImage(img, 0, 0, width, height);

            canvas.toBlob(blob => {
              if (!blob) return reject(new Error(\'Gagal membuat blob\'));
              const compressedFile = new File([blob], file.name, { type: blob.type });
              resolve(compressedFile);
            }, \'image/jpeg\', quality);
          };
        };
        reader.onerror = err => reject(err);
      });
    }
function tambah_file_upload() {
    const file_timeline_wrapper = $("#file_timeline_wrapper");
    const new_file_timeline = file_timeline_wrapper.find(".tr_file_timeline").last().clone();
    new_file_timeline.find("input").val("").attr("id", "id_tl_"+randomId());
    file_timeline_wrapper.append(new_file_timeline);
}
function randomId() {
    return Math.random().toString(36).substring(2, 15) + Math.random().toString(36).substring(2, 15);
}
function hapus_file_timeline(element) {
    if ($(".tr_file_timeline").length > 1) {
        $(element).closest(".tr_file_timeline").remove();
    } else {
        //alert("File timeline minimal 1");
    }
}

Demikian, semoga bermanfaat

Bagikan
rasupe

Recent Posts

Format angka dengan javascript

Bismillaahirrohmaanirrohiim... Berikut ini cara format angka menggunakan javascript, misalkan 1000 menjadi 1.000 atau 1500000 menjadi…

4 weeks ago

CPU 100% ternyata dipakai miner orang

Bismilaahirrohmaanirrohiim... jika server anda dipakai orang untuk mining, maka cpu usage akan habis dipakai dia,…

1 month ago

Cara Mematikan Mode SSL Virtualmin Webmin

Bismillaahirrohmaanirrohiim... masalah muncul saat akses https://ipaddress:10000 muncul seperti ini Error – Document follows This web…

3 months ago

eBook: menjadi kaya dimasa kini dan masa depan

Bismillahirrohmaanirrohiim... Ebook ini menghadirkan wawasan mendalam mengenai pergeseran kekayaan dari uang, aset, tanah, dan bahan…

4 months ago

Tombol back tutup modal bootstrap tanpa kembali ke halaman sebelumnya

Bismillaahirrohmaanirrohiim... Jika kita membuat aplikasi web base menggunakan bootstrap, saat user membuka modal, kadangkala mereka…

4 months ago

Kode css yang berguna

Bismillaahirrohmaanirrohiim... Berikut ini kumpulan css yang berguna, untuk mengingat saja. Input atau button delay saat…

4 months ago