在Web應用程序中使用Canvas API

更多HTML 5文章請查閱HTML 6在線網站http://www.html5online.com.cn

本文概述

    本文介紹如何在一個Web應用程序中利用HTML 5中的Canvas API創建、編輯、打開與輸出圖像。

檢測瀏覽器是否支持Canvas API
    首先,我們需要檢測用戶瀏覽器是否對HTML 5中的Canvas API提供支持。一個簡單的方法是利用Modernizr工具來進行檢測,方法如下所示。
if (Modernizr.canvas) {
    //瀏覽器支持Canvas API

else {
    //瀏覽器不支持Canvas API,使用諸如Flash、靜態圖片等其他技術
}
    通過URL地址或Data URI指定canvas元素中的圖像來源
    在使用Canvas API的時候,我們首先需要在頁面上放置一個canvas元素。然後,我們可以在JavaScript腳本代碼中將一幅圖像繪製在該canvas元素中,代碼如下所示。
var ctx = document.getElementById('canvas').getContext('2d');
var img = new Image();
img.src = "images/sl.jpg";
img.onload = function () {
    ctx.drawImage(img,0,0);
}
    在這段代碼中,我們首先獲取頁面上canvas元素的圖形上下文對象,通過該對象來使用Canvas API中所定義的所有可用於繪圖的方法。接下來,我們創建一個Image對象並且將該對象的src屬性值定義爲canvas元素中所需要繪製圖像的URL地址,這將使得所需要繪製的圖像將被裝載在該Image對象中。當該圖像裝載完畢後,我們使用canvas元素的圖形上下文對象的drawImage方法將該圖像繪製在canvas元素中。
    可以將該Image對象的src屬性值指定爲一個形式爲dataURI地址,代碼如下所示:
  img.src=""
    你也許會問:"爲什麼需要使用dataURI地址?",這是因爲dataURI地址有一些自身的優勢,例如接下來我們馬上要介紹的如何將canvas元素中的圖形或圖像導出爲一個data URI地址。
    將canvas元素中的圖像導出爲dataURI地址
    canvas元素有一個toDataURL方法,該方法將導出圖像的MIME類型作爲唯一參數,代碼如下所示。
window.open(document.getElementById('canvas').toDataURL("image/jpeg"));
    上面這行代碼將canvas元素中的圖像導出爲一個JPEG格式的圖像並且在新的瀏覽器窗口中打開該圖像。瀏覽器地址欄中顯示由canvas元素中的圖像生成的data URI地址,瀏覽器將根據該data URI地址渲染窗口中的圖像。但是,對於用戶來說就好像在新的瀏覽器窗口中打開了該圖像。
    另外請注意上面這行代碼必須被運行在一個Web服務器中。從本地文件系統中直接運行該代碼時瀏覽器將拋出錯誤。
將canvas元素中的圖像存儲在客戶端本地
    通過HTML 5中提供的各種將數據存儲在客戶端本地的技術,我們可以很輕鬆地將canvas元素中的圖像存儲在客戶端本地。
    例如通過如下所示的代碼,我們可以將canvas元素中的圖像存儲在WebStorage中。
localStorage.setItem('canvas', canvas.toDataURL("image/jpeg"));
    通過如下所示的代碼,我們可以從WebStorage中取出被保存的圖像。
localStorageImage = new Image();
canvas=document.getElementById('canvas');
ctx=canvas.getContext('2d');
localStorageImage.onload = function () 
{
    ctx.drawImage(image,0,0); 
}   
localStorageImage.src = localStorage.getItem('canvas');
    將canvas元素中的圖像上傳到服務器端
    有時,你可能想將canvas元素中的圖像上傳到服務器端。這時,我們可以首先利用canvas元素的toDataURL方法將canvas元素中的圖像輸出爲一個data URI地址,然後將該地址上傳到服務器端。該地址分爲兩部分,中間用逗號分割,其中第一部分爲“data:”+導出圖像的MIME類型+“;base64”,第二部分爲一個經過base64編碼的字符串,在服務器端將其解碼後即得到該圖像的原始二進制數據,可以將其保存爲圖像文件,代碼如下所示:
var data=canvas.toDataURL("image/jpeg");
var xhr = new XMLHttpRequest();
xhr.open("POST", "uploadImage.php");
xhr.send(data);
    服務器端保存圖像文件的代碼如下所示:
<?php
$data= $GLOBALS['HTTP_RAW_POST_DATA'];
$contents_split = explode(',',$data);
$encoded = $contents_split[count($contents_split)-1];
$decoded = "";
for ($i=0; $i < ceil(strlen($encoded)/256); $i++) {
    $decoded = $decoded . base64_decode(substr($encoded,$i*256,256));
}
$file=fopen("test.jpg","w");
fwrite($file,$decoded);
fclose($file);
?>

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章