Integrowanie Canvas z aplikacją internetową

Wstęp

Z tego artykułu dowiesz się, jak używać elementu canvas w języku HTML5 do tworzenia, edytowania, otwierania i eksportowania obrazów. Omówię też kilka narzędzi open source związanych z tą technologią i przedstawię kilka wskazówek dotyczących ich zastosowania w istniejących aplikacjach internetowych.

Sprawdź, czy masz pomoc dotyczącą kanw.

Najpierw sprawdź, czy Twoja przeglądarka w pełni obsługuje obiekty canvas HTML5. Możesz to łatwo zrobić za pomocą narzędzia Modernizr, aby sprawdzić określoną funkcję:

if (Modernizr.canvas) {
  // Browser supports native HTML5 canvas.
} else {
  // Fallback to another solution, such as Flash, static image, download link, and so on.
}

tworzenie elementu canvas i importowanie obrazu jako pliku binarnego lub identyfikatora URI danych,

Najpierw musisz mieć na swojej stronie element canvas. Używając JavaScriptu, możesz:

var ctx = document.getElementById('new_canvas').getContext('2d');
var img = new Image();
img.src = "html5.gif"
img.onload = function () {
   ctx.drawImage(img,0,0);
}

W tym kodzie pierwszym krokiem jest pobranie kontekstu 2D, co daje nam dostęp do API, który określa wszystkie metody i właściwości rysowania. Następnie tworzymy obiekt obrazu i ustawiamy właściwość src na lokalizację obrazu binarnego. Podczas wczytywania obrazu używamy metody pullImage(), by zaimportować go do elementu canvas. Zamiast adresu URL obrazu możesz też użyć identyfikatora URI danych. Zamiast korzystać z adresu URL powyżej możesz wykonać te czynności:

img.src=""

Możesz zapytać: „Dlaczego mamy używać identyfikatora URI danych zamiast obrazu binarnego?” Jest wiele zalet. Z dalszej części tego artykułu dowiesz się, jak łatwo wyeksportować obraz na płótnie jako identyfikator URI danych. Oto narzędzie do konwertowania pliku binarnego na identyfikator URI danych.

Manipulowanie obrazem kanwy

Jeśli kiedykolwiek zdarzyło Ci się korzystać z jakiegokolwiek programowania za pomocą logo, rysowanie na płótnie jest zgodne z tą samą koncepcją. Mark Pilgrim napisał rozdział na płótnie w swojej książce Dive Into HTML5. Opierając się na przykładzie z tego rozdziału, możemy dodać do zaimportowanego powyżej obrazu wykres siatki w następujący sposób:

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";

Możesz wykazać się większą kreatywnością, ale zostawię to w innych samouczkach wymienionych w załączniku do tego artykułu, gdzie znajdziesz dodatkowe instrukcje na ten temat. Nie zauważyliśmy jeszcze nic ekscytującego, ale w następnej sekcji to się zmieni.

Eksportowanie obrazu kanwy jako identyfikatora URI danych

Element canvas ma metodę toDataURL(), która jako parametr przyjmuje typ MIME. Dzięki temu możemy wyeksportować użytą wcześniej przestrzeń roboczą.

window.open(document.getElementById('ctx').toDataURL("image/png"));

Spowoduje to wyeksportowanie obszaru roboczego jako obrazu PNG do nowego okna przeglądarki. Nie jest to jednak zwykły binarny obraz, ale jest to identyfikator URI danych zakodowany w standardzie base64, który może być renderowany przez przeglądarkę. Tym samym z punktu widzenia użytkownika nie ma różnicy między wersją binarną a wersją binarną. Pamiętaj, że ten wiersz kodu musi zostać uruchomiony na serwerze WWW. Uruchomienie polecenia toDataURL() na pliku lokalnym kończy się niepowodzeniem. Stan tego problemu w Chrome znajdziesz w tym zgłoszeniu.

Integracja z aplikacją internetową

Canvas może być bardzo zaawansowanym dodatkiem do dowolnych aplikacji internetowych, które przechowują obrazy przesyłane przez użytkowników.

Obszar roboczy

Mamy na przykład aplikację do przechowywania plików online, w której można przechowywać zdjęcia przesłane przez użytkowników. Możemy dodać przycisk edycji, który pozwoli otworzyć plik obrazu w edytorze obrazów na płótnie. Jeśli nie chcesz pisać własnego edytora odbitek na płótnie, Harmony jest jednym z niewielu dostępnych edytorów odbitek na płótnie. Łatwy w użyciu pędzel, który zaspokoi Twój gust artystyczny. Po wybraniu „Edytuj obraz” w menu pokazanym powyżej powinien zostać otwarty edytor kanwy, który wywoła niestandardową funkcję read_file() w funkcji init() edytora w następujący sposób:

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')
   }
}
Harmony

Dodawanie pamięci lokalnej HTML5

Jeśli zależy Ci na wygodzie użytkowników, warto zastosować usługę LocalStorage. Możesz to zrobić na przykład wtedy, gdy masz duży obszar tekstu, a użytkownik musi wpisać dużo informacji. Gdy użytkownik zamierza przesłać formularz, przypadkowo zamyka przeglądarkę (lub ulega awarii). użytkownik może być sfrustrowany i nie chce ponownie pisać wiadomości. W poniższym przykładzie zamiast zapisywać dane na serwerze, zapisz obraz w LocalStorage jako identyfikator URI danych:

// 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');
        }
//...
}

Zapisywanie na serwerze obszaru roboczego jako pliku binarnego

Obraz na płótnie możesz zapisać jako plik binarny. Możesz to zrobić na wiele sposobów. Możesz na przykład wykonać działanie POST, aby przekazać identyfikator URI danych do kodu backendu. W przypadku biblioteki jQuery kod będzie wyglądał tak:

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');

Spowoduje to utworzenie wywołania XHR, którego treść jest identyfikatorem URI danych. Następnie musisz zdekodować na serwerze identyfikator URI danych base64. Na przykład w języku PHP możesz:

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
}

W pierwszych dwóch wierszach identyfikator URI danych ($contents) jest podzielony na dwie części. 'data:image/png;base64' i 'VBORw0KGgoAAAANSUhEUgAAAWwAAAB+CAIAAACPlLzKAAAACXBIWXMAAC4jAAAuIwF4pT92...' Użyjemy następnie base64_decode() do zdekodowania ciągu URI danych. Problem polega na tym, że występują problemy z dekodowaniem ciągu znaków przekraczającego 5K i metoda „dziel i zdalizuj”, która umożliwia zdekodowanie ciągu. Na koniec używając funkcji fwrite(), możesz zapisać na serwerze plik binarny $contents.

Włączanie opcji „Zapisz obraz” w przeglądarce

Canvas to element HTML. Wygląda on bardzo podobnie do obrazu, ale w przeglądarce nie ma opcji „Zapisz obraz jako”, ponieważ w rzeczywistości nie jest to element graficzny. Aby włączyć opcję „Zapisz obraz jako”, możesz dynamicznie utworzyć element Img, a w atrybucie src ustawić identyfikator URI danych elementu canvas. Możesz też użyć narzędziacanvas2image.

Bardziej zaawansowany edytor kanw

Jeśli szukasz bardziej zaawansowanego edytora odbitek na płótnie, warto wypróbować PaintWeb. Został on napisany przez rumuńskiego studenta Mihaia Sucan podczas wydarzenia Google Summer of Code w 2009 roku. Jest też autorem kilku samouczków dotyczących pisania własnych aplikacji malarskich online.

Renderowanie stron

Jeśli potrzebujesz bardziej profesjonalnej biblioteki, sprawdź program Pixati.

Więcej zabawy z odbitkami na płótnie?

Paul Ireland połączył Harmony z rozpoznawaniemw wysokości 1 USD</br class="ph-1-1"> i utworzył mały jajko.

Możesz też dowiedzieć się, jak sprawdzić obszar roboczy w Narzędziach deweloperskich w Chrome, korzystając z najnowszych funkcji inspekcji.

Dowiedz się więcej dzięki dodatkowym samouczkom dotyczącym Canvas