<canvas>
este unul din cele mai interesante elemente introduse in HTML5.
Tag-ul <canvas> este destul de simplu, defineste lungimea, inaltimea si un ID unic. Dar se folosesc o serie de instructiuni JavaScript (denumite generic APIs) pentru a desena obiecte in canvas.
Exemplu de mai jos arata structura de baza pentru implementare canvas intr-o pagina web:
<canvas id='id_canvas' width='200' height='200'></canvas> <script> function draw() { // preia intr-un obiect tag-ul <canvas> var canvas = document.getElementById('id_canvas'); // daca browser-ul recunoaste canvas if (canvas.getContext) { var ctx = canvas.getContext('2d'); // Aplica instructiuni JavaScript (API canvas) pt. desenare } } // apeleaza functia draw() draw(); </script>- Atributele
width
si height
specifica dimensiunile zonei CANVAS in pagina web.<canvas>
intr-un obiect (cu document.getElementById('ID')), apoi se aplica functii si proprietati specifice pentru a crea desene care sunt afisate in tag-ul CANVAS.getContext('2d')
trebuie aplicata la elementul Canvas ca sa se obtina un obiect la care se aplica instructiuni API pentru crearea continutului din <canvas>.
<canvas> este un element de tip inline, poate fi adaugat in oricare tag de tip bloc, precum <p>, <div>, sau in elementele noi de structura introduse in HTML5: <section>, <article>.
Instructiunile JavaScript permit dezvoltatorilor de pagini web sa deseneze diferite forme, linii, sa aplice culori, transparenta si gradient, sa adauge text si imagini in Canvas; chiar sa creeze animatie.
- Exemplu urmator deseneaza un patrat albastru.
<h4>Exemplu desenare patrat in canvas</h4> <canvas width='200' height='200' id='cav1'></canvas> <script> function draw() { var canvas = document.getElementById('cav1'); if (canvas.getContext) { var ctx = canvas.getContext('2d'); ctx.fillStyle = '#0101fe'; ctx.fillRect (50, 60, 100, 100); } } draw(); // calls the draw() function </script>
ctx.fillStyle = 'Culoare'
- reprezinta culoarea din interiorul formei. Se poate folosi orice metoda de definire a culorii utilizata in CSS (blue, #0000ff, #00f, sau rgb(0,0,255) ).ctx.fillRect(X-stanga, Y-sus, lungime, inaltime)
- Deseneaza patrulaterul in canvas, folosind cloarea din 'fillStyle'.Ca sa adaugati transparenta, definiti culoarea folosind formula: rgba(Red, Green, Blue, Alpha)
. 'Alpha' e o valoare intre 0 si 1 care reprezinta transparenta.
In urmatorul exemplu adaugam un dreptunghi cu Alpha 0.5. In acest caz definim culoarea din fillStyle
pentru dreptunghi folosind rgba()
pentru a specifica valoarea de transparenta ( 'rgba(220, 223, 0, 0.5)' ).
<h4>Canvas - culoare cu transparenta</h4> <canvas width='200' height='200' id='cav1'></canvas> <script> function draw() { var canvas = document.getElementById('cav1'); if (canvas.getContext) { var ctx = canvas.getContext('2d'); ctx.fillStyle = '#0101fe'; ctx.fillRect (50, 60, 100, 100); ctx.fillStyle = 'rgba(220,223,0, 0.5)'; ctx.fillRect (90, 105, 100, 80); } } draw(); // calls the draw() function </script>
Ca sa desenati linii se foloseste functia lineTo()
.
moveTo()
.
ctx.strokeStyle = 'culoare';
ctx.lineWidth = valoare;
Dupa ce a fost definita culoarea liniei (cu strokeStyle), si grosimea (cu lineWidth), am folosit metoda moveTo() pentru a seta punctul de inceput, apoi cu lineTo(100, 80) se creaza o linie de la acel punct curent pana la punctul dat de coordonatele (100, 80).
Acum, ultimul punct devine punctul curent de inceput, pentru a-l muta, se foloseste iar meoda moveTo().
<h4>Exemplu canvas desenare linii</h4> <canvas width='200' height='200' id='cav1'></canvas> <script> function draw() { var canvas = document.getElementById('cav1'); if (canvas.getContext) { var ctx = canvas.getContext('2d'); // define line color and width ctx.strokeStyle = '#01da01'; ctx.lineWidth = 3; // create the first line ctx.moveTo(10, 10); // sets the start point ctx.lineTo(100, 80); // define a line till these coordinates // create the second line ctx.moveTo(10, 10); // sets the start point ctx.lineTo(120, 120); // define a line till these coordinates // the third line ctx.moveTo(10, 150); // moves start point ctx.lineTo(140, 150); ctx.stroke(); // draw the strokes } } draw(); // calls the draw() function </script>
Pentru a desena arce de cerc si cercuri, se foloseste functia arc()
.
arc()
, aplicati:Desenul incepe cu desenarea fetei, apoi se muta punctul de inceput pentru desenare gura, si traseaza alt arc de cerc, si tot asa pentru fiecare ochi. Functia moveTo() se ocupa de mutarea coordonatelor.
<h4>Exemplu canvas - arce si cercuri</h4> <canvas width='200' height='200' id='cav1'></canvas> <script> function draw() { var canvas = document.getElementById('cav1'); if (canvas.getContext) { var ctx = canvas.getContext('2d'); ctx.arc(75,75,50,0,Math.PI*2,true); // Face ctx.moveTo(110,75); ctx.arc(75,75,35,0,Math.PI,false); // Mouth ctx.moveTo(65,65); ctx.arc(60,65,4,0,Math.PI*2,true); // Left eye ctx.moveTo(95,65); ctx.arc(90,65,4,0,Math.PI*2,true); // Right eye ctx.stroke(); } } draw(); </script>
Sunt doua metode pentru adaugare text in canvas:
<h4>Exemplu text in canvas</h4> <canvas width='200' height='200' id='cav1'></canvas> <script> function draw() { var canvas = document.getElementById('cav1'); if (canvas.getContext) { var ctx = canvas.getContext('2d'); // create text with fill color ctx.fillStyle = '#00f'; ctx.font = 'italic 30px sans-serif'; ctx.textBaseline = 'top'; ctx.fillText('Hy everyone', 2, 5); // create text without fill color ctx.font = 'bold 30px sans-serif'; ctx.strokeText('Hy everyone', 2, 50); } } draw(); </script>
Instrctiunile JavaScript pentru umbre contin proprietati care se aplica la obiectul context:
<h4>Exemplu canvas - umbra</h4> <canvas width='200' height='200' id='cav1'></canvas> <script> function draw() { var canvas = document.getElementById('cav1'); if (canvas.getContext) { var ctx = canvas.getContext('2d'); // sets shadow properties ctx.shadowOffsetX = 8; ctx.shadowOffsetY = 8; ctx.shadowBlur = 4; ctx.shadowColor = 'rgba(200, 200, 1, 0.5)'; // define and add a circle ctx.fillStyle = '#0000fe'; ctx.arc(75,75,50,0,Math.PI*2,true); ctx.fill(); } } draw(); </script>
Pentru a crea culoare gradient in Canvas, se aplica un obiect CanvasGradient
la proprietatile fillStyle
sau /si strokeStyle
.
Se pot crea doua tipuri de obiect CanvasGradient
, utilizand una din urmatoarele metode:
addColorStop()
aplicata acestui obiect. Urmatoarele doua coduri arata cum puteti crea si folosi gradient.createLinearGradient()
:
<h4>Exemplu canvas - Gradient</h4> <canvas width='200' height='200' id='cav1'></canvas> <script> function draw() { var canvas = document.getElementById('cav1'); if (canvas.getContext) { var ctx = canvas.getContext('2d'); // create a Linear CanvasGradient object // provide the source, the start and end (x0, y0, x1, y1) coordinates var gradient = ctx.createLinearGradient(0, 0, 150, 0); // Now add colors in your gradient, the first argument tells the position for the color // - accepted value range is from 0 (gradient start) to 1 (gradient end) // The second argument tells the color you want, using the CSS color format gradient.addColorStop(0, '#f00'); // red gradient.addColorStop(0.4, '#ff0'); // yellow gradient.addColorStop(0.8, '#0f0'); // green gradient.addColorStop(1, '#00f'); // blue // Apply the gradient to fillStyle property, and draw an rectangle ctx.fillStyle = gradient; ctx.fillRect(0, 0, 200, 125); } } draw(); </script>
createRadialGradient()
:
<h4>Exemplu canvas - Gradient cu createRadialGradient()</h4> <canvas width='200' height='200' id='cav1'></canvas> <script> function draw() { var canvas = document.getElementById('cav1'); if (canvas.getContext) { var ctx = canvas.getContext('2d'); // create a Radial CanvasGradient object // provide the source, the start, end and radius (x0, y0, r0, x1, y1, r1) of the circles var gradient = ctx.createRadialGradient(70, 80, 10, 78, 75, 45); // Adding colors to a radial gradient is the same as adding colors to linear gradient.addColorStop(0, '#0f0'); gradient.addColorStop(0.5, '#fff'); gradient.addColorStop(1, '#00f'); // Apply the gradient to fillStyle property, and draw an circle ctx.fillStyle = gradient; ctx.arc(75,75,50,0,Math.PI*2,true); ctx.fill(); } } draw(); </script>
Pentru a adauga o imagine in <canvas>, se foloseste metoda drawImage()
. E o functie complexa, care foloseste trei, cinci, sau noua argumente.
Iata sintaxa cu cinci argumente:
<h4>Exemplu canvas - imagine</h4> <canvas width='280' height='200' id='cav1'></canvas> <script> function draw() { var canvas = document.getElementById('cav1'); if (canvas.getContext) { var ctx = canvas.getContext('2d'); // create an object with the image, then adds it in canvas context (resizing it) var img = new Image(); img.src ='html/html_course.jpg'; ctx.drawImage(img, 0, 0, 95, 100); // add a text without fill color ctx.font = 'bold 25px sans-serif'; ctx.textBaseline = 'top'; ctx.strokeText('HTML Course', 100, 38); } } draw(); </script>
Proprietatea fillStyle foloseste o culoare preluata din parametru 'clr', astfel, cand functia e apelata cu o culoare diferita la argument, afiseaza un dreptunghi cu alta culoare.
<h4>Exemplu canvas - evenimente</h4> <p>Pozitionati mouse-ul deasupra dreptunghiului si apasati click pe el.</p> <canvas width='125' height='85' id='cav1'></canvas> <script> var canvas = document.getElementById('cav1'); //receives the color function draw(clr){ if (canvas.getContext) { var ctx = canvas.getContext('2d'); // draw a rectangle, using a fill color defined in 'clr' parameter ctx.fillStyle = clr; ctx.fillRect (0, 0, 120, 80); } } draw('#0102fe'); //register events that call draw() with desired color canvas.addEventListener('mouseenter', (ev)=>{ draw('#fefe01'); }); canvas.addEventListener('mouseleave', (ev)=>{ draw('#01de02'); }); canvas.addEventListener('click', (ev)=>{ draw('#fe0708'); }); </script>
<p>Cursuri, Jocuri, Anime: <em>www.MarPlo.net</em></p>
h3 { padding: 2px 0.2em; }
// preia primul Div cu class="cls", si afiseaza continutul var elm = document.querySelector("div.cls"); alert(elm.innerHTML);
if(isset($_POST["field"])) { echo $_POST["field"]; }
We speak english. - Noi vorbim engleza.
Nosotros hablamos español. - Noi vorbim spaniola.