首頁  >  文章  >  後端開發  >  Canvas與圖片壓縮的範例程式碼

Canvas與圖片壓縮的範例程式碼

小云云
小云云原創
2017-12-05 13:40:571458瀏覽

canvas 元素用於在網頁上繪製圖形。 HTML5 的 canvas 元素使用 JavaScript 在網頁上繪製2D圖像。在矩形區域的畫布上,JavaScript 繪製 2D圖形,逐像素進行渲染,可以透過多種方法使用canvas元素繪製路徑、矩形、圓形、字元以及添加圖像。本文我們和大家分享Canvas與圖片壓縮的範例程式碼。

Canvas圖片壓縮流程

#接下來我將以具體實例為大家講解Canvas圖片壓縮的具體流程。

一、本機圖片輸入

1. 取得本機檔案

<!--HTML-->
<input type="file" id="choose-img" />

// JS
var chooseImg = document.getElementById("choose-img");
chooseImg.onchange = function(e){
    var file = this.files[0];
    // ……  (省略部分代码后续依次展示,下同)
};

很簡單,就是透過type類型為file的按鈕來取得本機檔案。

2.判斷所取得的本機檔案類型

#
<!--HTML-->
<p id="result"></p>

// JS
var result = document.getElementById("result");    // 用于显示图片输出结果,或者错误提示
if(/image/.test(file.type)){     // 判断文件类型是否为图片
    // ……
}
else{
    result.innerHTML = &#39;<span style="color: red;">文件类型有误!</span>&#39;;
}

##3. 將所取得的本機圖片以base64格式輸出

#
var img = new Image(),      // 创建图片对象,用于放置原始图片
    reader = new FileReader();
reader.readAsDataURL(file);    // 以base64格式读取并存入FileReader对象的result属性中
reader.onload = function(){
    img.src = this.result;   // 将图片base64字符串直接赋予Image对象的src中
    document.body.insertBefore(img,chooseImg);   // 将输出的图片插入到文件按钮之前
    img.onload = function(){
        // ……
    };
};

2、在Canvas畫布中繪製圖片

1. 建立畫布

#
var canvas = document.createElement(&#39;canvas&#39;);
canvas.width = img.clientWidth;
canvas.height = img.clientHeight;
var context = canvas.getContext(&#39;2d&#39;);

注意:畫布大小與所輸入圖片寬高相同。

2. 繪製圖片

context.drawImage(img,0,0,canvas.width,canvas.height);

三、壓縮圖片並輸出

<!--HTML-->
图片压缩比率 : <input id="rate" type="number" min="0" max="100" /> %

// JS
var rate = document.getElementById("rate").value || 100;   // 输入图片压缩比率,默认为100%
var imgUrl = canvas.toDataURL(file.type,rate/100);   // 第一个参数为输出图片类型,第二个为压缩比
result.innerHTML = &#39;压缩后:<img src="&#39;+ imgUrl +&#39;" />&#39;;     // 将压缩后的图片置于result中显示
img.style.display = &#39;none&#39;;   // 将原始图片隐藏

#將在Canvas畫布中所繪製的圖片再次以base64格式輸出。

四、完整程式碼展示############
<!--HTML-->
图片压缩比率 : <input id="rate" type="number" min="0" max="100" /> %

############
// JS
var chooseImg = document.getElementById("choose-img"),
    result = document.getElementById("result");
chooseImg.onchange = function(e){
    var file = this.files[0];
    if(/image/.test(file.type)){
        var img = new Image(),
            reader = new FileReader();
        reader.readAsDataURL(file);
        reader.onload = function(){
            img.src = this.result;
            document.body.insertBefore(img,chooseImg);
            img.onload = function(){
                var canvas = document.createElement(&#39;canvas&#39;);
                canvas.width = img.clientWidth;
                canvas.height = img.clientHeight;
                var context = canvas.getContext(&#39;2d&#39;);
                context.drawImage(img,0,0,canvas.width,canvas.height);
                var rate = document.getElementById("rate").value || 100;
                var imgUrl = canvas.toDataURL(file.type,rate/100);
                result.innerHTML = &#39;压缩后:<img src="&#39;+ imgUrl +&#39;" />&#39;;
                result.style.display = &#39;block&#39;;
                img.style.display = &#39;none&#39;;
            };
        };
    }
    else{
        result.innerHTML = &#39;<span style="color: red;">文件类型有误!</span>&#39;;
    }
};
#########經測試發現,透過Canvas壓縮JPEG格式圖片效果最佳,PNG壓縮效果不明顯,有時反而變得更大。 ######以上內容就是Canvas與圖片壓縮的範例程式碼,希望能幫助大家。 ######相關推薦:#########怎麼用canvas實作小球與滑鼠的互動############怎麼用canvas做出粒子噴泉動畫的效果############HTML5裡Canvas常用的繪圖技巧#############canvas製作滑鼠拖曳繪製圖形############實例詳解html5使用canvas實作圖片下載功能######

以上是Canvas與圖片壓縮的範例程式碼的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn