Giới thiệu
Trong bài viết này, tôi sẽ thảo luận về cách sử dụng phần tử canvas HTML5 để tạo, chỉnh sửa, mở và xuất hình ảnh. Tôi cũng sẽ giới thiệu một số công cụ nguồn mở có liên quan đến công nghệ này và đưa ra một số mẹo về cách áp dụng các kỹ thuật này cho một ứng dụng web hiện có.
Kiểm tra xem có hỗ trợ ảnh in trên vải canvas không
Việc đầu tiên cần làm là kiểm tra để đảm bảo trình duyệt của bạn hỗ trợ đầy đủ canvas HTML5. Một cách dễ dàng để làm điều đó là sử dụng Modernizr để kiểm tra một tính năng nhất định:
if (Modernizr.canvas) {
// Browser supports native HTML5 canvas.
} else {
// Fallback to another solution, such as Flash, static image, download link, and so on.
}
Tạo phần tử canvas và nhập hình ảnh dưới dạng tệp nhị phân hoặc URI dữ liệu
Trước tiên, bạn cần có một phần tử canvas trong trang. Khi sử dụng JavaScript, bạn hãy làm như sau:
var ctx = document.getElementById('new_canvas').getContext('2d');
var img = new Image();
img.src = "html5.gif"
img.onload = function () {
ctx.drawImage(img,0,0);
}
Trong mã này, bước đầu tiên là lấy ngữ cảnh 2D, cho phép chúng ta truy cập vào API xác định tất cả các phương thức và thuộc tính vẽ. Tiếp theo, chúng ta tạo một đối tượng hình ảnh và đặt thuộc tính src thành vị trí của hình ảnh nhị phân. Khi hình ảnh được tải, chúng ta sẽ sử dụng phương thức drawImage() để nhập hình ảnh vào phần tử canvas. Bạn cũng có thể sử dụng URI dữ liệu thay vì URL của hình ảnh. Vì vậy, thay vì URL ở trên, bạn có thể làm như sau:
img.src=""
Bạn có thể hỏi: "Tại sao chúng ta lại sử dụng URI dữ liệu thay vì hình ảnh nhị phân?" Có nhiều lợi thế. Và sau đó trong bài viết này, bạn sẽ thấy chúng ta có thể dễ dàng xuất hình ảnh canvas dưới dạng URI dữ liệu. Dưới đây là một công cụ để chuyển đổi tệp hình ảnh nhị phân thành URI dữ liệu.
Thao tác với hình ảnh canvas
Nếu bạn từng thực hiện bất kỳ loại lập trình biểu trưng nào, thì việc vẽ trên canvas cũng sử dụng cùng một khái niệm. Mark Pilgrim có một chương về canvas trong cuốn sách của mình, Dive Into HTML5 (Tìm hiểu về HTML5). Dựa trên ví dụ trong chương này, chúng ta có thể thêm sơ đồ lưới vào hình ảnh đã nhập ở trên bằng cách sử dụng nội dung sau:.
var img2 = new Image();
img2.onload = function () {
var context2 = document.getElementById('new_canvas2').getContext('2d');
/* vertical lines then horizontal ones */
for (var x = 0.5; x < 800; x += 10) { context2.moveTo(x, 0); context2.lineTo(x, 500); }
for (var y = 0.5; y < 500; y += 10) { context2.moveTo(0, y); context2.lineTo(800, y); }
context2.strokeStyle = "#bbb";
context2.stroke();
context2.drawImage(img2,0,0);
}
img2.src = "html5.gif";
Bạn có thể sáng tạo hơn thế, nhưng tôi sẽ để các hướng dẫn khác được liệt kê trong phần phụ lục của bài viết này hướng dẫn thêm về chủ đề đó. Chúng ta chưa thấy điều gì thú vị, nhưng phần tiếp theo sẽ thay đổi điều đó.
Xuất hình ảnh canvas dưới dạng URI dữ liệu
Phần tử canvas có phương thức toDataURL()
, lấy loại MIME làm tham số. Với điều này, chúng ta có thể xuất canvas đã sử dụng ở trên.
window.open(document.getElementById('ctx').toDataURL("image/png"));
Thao tác này sẽ xuất canvas dưới dạng hình ảnh PNG vào một cửa sổ trình duyệt mới. Tuy nhiên, hình ảnh này không phải là hình ảnh nhị phân thông thường mà là một URI dữ liệu được mã hoá base64 mà trình duyệt có thể hiển thị. Do đó, từ quan điểm của người dùng, không có sự khác biệt giữa tệp đó và tệp tương đương nhị phân.
Xin lưu ý rằng dòng mã ở trên cần được chạy trên máy chủ web. Bạn sẽ không thể chạy toDataURL()
trên tệp cục bộ. Hãy xem phiếu yêu cầu hỗ trợ này để biết trạng thái của vấn đề này trong Chrome.
Tích hợp vào ứng dụng web
Canvas có thể là một tiện ích bổ sung rất mạnh mẽ cho mọi ứng dụng web lưu trữ hình ảnh do người dùng tải lên.

Ví dụ: chúng tôi có một ứng dụng lưu trữ tệp trực tuyến lưu trữ hình ảnh do người dùng tải lên. Chúng ta có thể thêm nút chỉnh sửa để mở tệp hình ảnh trong trình chỉnh sửa ảnh dựa trên canvas.
Nếu bạn không muốn tự viết trình chỉnh sửa canvas, Harmony là một trong số ít trình chỉnh sửa canvas có sẵn. Ứng dụng này có tính năng thêm bút vẽ dễ dàng, có thể đáp ứng được sở thích nghệ thuật của bạn.
Khi bạn chọn "edit image" (chỉnh sửa hình ảnh) trong trình đơn minh hoạ ở trên, một trình chỉnh sửa canvas sẽ mở ra và thực hiện lệnh gọi đến hàm read_file()
tuỳ chỉnh trong hàm init() của trình chỉnh sửa như sau:
function read_file() {
var url = file_id;
// hide a copy of the original image if it is needed to load
document.getElementById('editableImage').src = url;
image = new Image();
image.src = url;
image.onload = function() {
context.drawImage(image,0,0); // context, defined above, as canvas.getContext('2d')
}
}

Thêm LocalStorage HTML5
Một điểm chỉnh sửa nhỏ mà bạn luôn nên cân nhắc (nếu quan tâm đến trải nghiệm người dùng) là áp dụng LocalStorage. Ví dụ: nếu bạn có một vùng văn bản lớn yêu cầu người dùng nhập nhiều thông tin. Khi sắp gửi biểu mẫu, người dùng vô tình đóng trình duyệt (hoặc trình duyệt gặp sự cố). Người dùng có thể sẽ thất vọng và không muốn viết lại thư. Trong bản minh hoạ bên dưới, thay vì lưu dữ liệu vào máy chủ, bạn chỉ cần lưu hình ảnh vào LocalStorage dưới dạng URI dữ liệu:
// Save Image
function saveToLocalStorage() {
localStorage.setItem('canvas', canvas.toDataURL('image/png'));
}
// Load Image
function init() {
// for demo purpose, all variables are declared in the parent scope
canvas = document.createElement('canvas');
context = canvas.getContext('2d');
// Use Modernizr to detect whether localstorage is supported by the browser
if (Modernizr.localstorage && localStorage.getItem('canvas'))
{
localStorageImage = new Image();
localStorageImage.addEventListener("load", function (event) {
//...
context.drawImage(localStorageImage, 0, 0);
}, false);
localStorageImage.src = localStorage.getItem('canvas');
}
//...
}
Lưu canvas dưới dạng tệp nhị phân trên máy chủ
Bạn nên lưu hình ảnh canvas dưới dạng tệp nhị phân. Có nhiều cách để làm việc này. Ví dụ: bạn có thể thực hiện thao tác POST để truyền URI dữ liệu đến mã phụ trợ. Khi sử dụng jQuery, mã sẽ có dạng như sau:
var url = '/api/write/' + file_id + '?data_url_to_binary=1';
var data_url = flattenCanvas.toDataURL('image/png');
var params = { contents: data_url };
$j.post(url, params, function(json){
if (json.status == 'upload_ok')
{
//ok
}
}, 'json');
Thao tác này sẽ tạo một lệnh gọi XHR với nội dung là URI dữ liệu. Sau đó, bạn cần giải mã URI dữ liệu base64 trên máy chủ. Ví dụ: trong PHP, bạn có thể làm như sau:
if ($_GET['data_url_to_binary'])
{
$contents_split = explode(',', $contents);
$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));
}
$contents = $decoded; // output
}
Trong hai dòng đầu tiên, URI dữ liệu ($contents) được chia thành hai phần. 'data:image/png;base64'
và 'VBORw0KGgoAAAANSUhEUgAAAWwAAAB+CAIAAACPlLzKAAAACXBIWXMAAC4jAAAuIwF4pT92...'
Sau đó, chúng ta sẽ sử dụng base64_decode()
để giải mã chuỗi URI dữ liệu. Bí quyết ở đây là có các vấn đề về việc giải mã chuỗi lớn hơn 5K và phương pháp "chia để trị" này sẽ có thể giải mã chuỗi.
Cuối cùng, bằng cách sử dụng fwrite(), bạn có thể lưu tệp nhị phân $contents vào máy chủ của mình.
Bật tính năng "lưu hình ảnh" trong trình duyệt
Canvas là một phần tử HTML. Hình ảnh này trông khá giống hình ảnh, nhưng trình duyệt của bạn không cung cấp tuỳ chọn "Lưu hình ảnh dưới dạng" vì đây không thực sự là phần tử hình ảnh. Để bật tính năng "Save Image As" (Lưu hình ảnh dưới dạng), bạn có thể tạo động phần tử Img và đặt src thành URI dữ liệu của phần tử canvas. Bạn cũng có thể sử dụng tiện ích canvas2image.
Trình chỉnh sửa canvas nâng cao hơn
Nếu bạn đang tìm kiếm một trình chỉnh sửa canvas nâng cao hơn, thì bạn nên thử PaintWeb. Tài liệu này do Mihai Sucan, một sinh viên người Romania, viết trong chương trình Google Summer of Code 2009. Anh cũng là tác giả của một số hướng dẫn về cách viết ứng dụng vẽ trực tuyến của riêng bạn.

Để có một thư viện chuyên nghiệp hơn, hãy nhớ tham khảo Pixati.
Bạn muốn có nhiều niềm vui hơn với canvas?
Paul Irish đã kết hợp Harmony và Trình nhận dạng Unistroke $1 để tạo một Trứng Phục sinh nhỏ trên trang web của mình.
Bạn cũng có thể tìm hiểu cách kiểm tra canvas bằng Chrome DevTools thông qua các tính năng kiểm tra mới đây của chúng tôi.
Tìm hiểu sâu hơn qua các hướng dẫn bổ sung về canvas
- MDN: Hướng dẫn về Canvas
- Tìm hiểu về HTML5: Canvas
- HTML5 canvas – kiến thức cơ bản trên Dev.Opera trình bày các yếu tố vẽ cơ bản
- Tạo bản sao Breakout trong canvas bao gồm các yếu tố cơ bản về chuyển động, vật lý và khả năng tương tác