Jump to content

Recommended Posts

Posted

What is Canvas?

 

The HTML5 <canvas> element is used to draw graphics, on the fly, via scripting (usually JavaScript).

 

The <canvas> element is only a container for graphics. You must use a script to actually draw the graphics.

 

Canvas has several methods for drawing paths, boxes, circles, characters, and adding images.

Browser Support

 

Internet Explorer,Firefox,Opera,Google Chrome,Safari

 

Internet Explorer 9, Firefox, Opera, Chrome, and Safari support the <canvas> element.

 

Note: Internet Explorer 8 and earlier versions, do not support the <canvas> element.

Create a Canvas

 

A canvas is a rectangular area on an HTML page, and it is specified with the <canvas> element.

 

Note: By default, the <canvas> element has no border and no content.

 

The markup looks like this:

<canvas id="myCanvas" width="200" height="100"></canvas> 

Note: Always specify an id attribute (to be referred to in a script), and a width and height attribute to define the size of the canvas.

 

Tip: You can have multiple <canvas> elements on one HTML page.

 

To add a border, use the style attribute:

<canvas id="myCanvas" width="200" height="100"
style="border:1px solid #000000;">
</canvas> 

 

Draw Onto The Canvas With JavaScript

 

All drawing on the canvas must be done inside a JavaScript:

<script>
var c=document.getElementById("myCanvas");
var ctx=c.getContext("2d");
ctx.fillStyle="#FF0000";
ctx.fillRect(0,0,150,75);
</script> 

Example explained:

 

First, find the <canvas> element:

var c=document.getElementById("myCanvas"); 

Then, call its getContext() method (you must pass the string "2d" to the getContext() method):

var ctx=c.getContext("2d"); 

The fillStyle property can be a CSS color, a gradient, or a pattern. The default fillStyle is #000000 (black).

 

The fillRect(x,y,width,height) method draws a rectangle filled with the current fill style.

Canvas Coordinates

 

The canvas is a two-dimensional grid.

 

The upper-left corner of the canvas has coordinate (0,0)

 

So, the fillRect() method above had the parameters (0,0,150,75).

 

This means: Start at the upper-left corner (0,0) and draw a 150x75 pixels rectangle.

 

Canvas - Paths

To draw straight lines on a canvas, we will use the following two methods:

 

    moveTo(x,y) defines the starting point of the line

    lineTo(x,y) defines the ending point of the line

 

To actually draw the line, we must use one of the "ink" methods, like stroke().

 

JavaScript:

var c=document.getElementById("myCanvas");
var ctx=c.getContext("2d");
ctx.moveTo([i]0,0[/i]);
ctx.lineTo([i]300,150[/i]);
ctx.stroke();

 

To draw a circle on a canvas, we will use the following method:

 

    arc(x,y,r,start,stop)

 

To actually draw the circle, we must use one of the "ink" methods, like stroke() or fill().

 

JavaScript:

var c=document.getElementById("myCanvas");
var ctx=c.getContext("2d");
ctx.beginPath();
ctx.arc([i]95,50,40,0,2*Math.PI[/i]);
ctx.stroke();

Canvas - Text

 

To draw text on a canvas, the most important property and methods are:

 

    font - defines the font properties for text

    fillText(text,x,y) - Draws "filled" text on the canvas

    strokeText(text,x,y) - Draws text on the canvas (no fill)

 

JavaScript:

var c=document.getElementById("myCanvas");
var ctx=c.getContext("2d");
ctx.font="30px Arial";
ctx.fillText("Hello World",10,50);

 

Gradients can be used to fill rectangles, circles, lines, text, etc. Shapes on the canvas are not limited to solid colors.

 

There are two different types of gradients:

 

    createLinearGradient(x,y,x1,y1) - Creates a linear gradient

    createRadialGradient(x,y,r,x1,y1,r1) - Creates a radial/circular gradient

 

Once we have a gradient object, we must add two or more color stops.

 

The addColorStop() method specifies the color stops, and its position along the gradient. Gradient positions can be anywhere between 0 to 1.

 

To use the gradient, set the fillStyle or strokeStyle property to the gradient, and then draw the shape, like a rectangle, text, or a line.

 

Javscript:

var c=document.getElementById("myCanvas");
var ctx=c.getContext("2d");

// Create gradient
var grd=ctx.createLinearGradient([i]0,0,200,0[/i]);
grd.addColorStop(0,"red");
grd.addColorStop(1,"white");

// Fill with gradient
ctx.fillStyle=grd;
ctx.fillRect([i]10,10,150,80[/i]);

 

Using createRadialGradient():

Javascript:

var c=document.getElementById("myCanvas");
var ctx=c.getContext("2d");

// Create gradient
var grd=ctx.createRadialGradient([i]75,50,5,90,60,100[/i]);
grd.addColorStop(0,"red");
grd.addColorStop(1,"white");

// Fill with gradient
ctx.fillStyle=grd;
ctx.fillRect([i]10,10,150,80[/i]);

 

 

Canvas - Images

 

To draw an image on a canvas, we will use the following method:

 

    drawImage(image,x,y)

Javascript:

var c=document.getElementById("myCanvas");
var ctx=c.getContext("2d");
var img=document.getElementById("scream");
ctx.drawImage(img,[i]10,10[/i]);

(http://www.roadoutofdebt.com/wp-content/uploads/2011/11/the-scream.jpg)

 

Credits Olympus,Internet,ME.

 

 

 

 

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now


  • Posts

    • This is very unprofessional. First the price was €10k or maybe €5k then it dropped to $1k After that, he made people think the 166 protocol was fully added, but that is not true. I also have friends who talked to him, and he asked them for different prices in dollars. He does not have a fixed price. Also, the files are not finished. Anyone can make a login with 166 protocol and make it look good, but that does not mean the whole project is done. This kind of work takes a lot of time, and everyone knows that. So be careful if you want to buy files from this person. They are not finished. RIP  
    • L2 Reborn Eternal x10 community board HTML ONLY. Does not have function or Interface.xdat for the tabs. You are responsible to make the functions yourself.      Download
    • TG Support: https://t.me/buyingproxysup | Channel: https://t.me/buyingproxycom Discord support: #buyingproxy | Server: Join the BuyingProxy Discord Server!  Create your free account here
    • Dalam World — This is a new gaming project that brings together all the mechanics of your favorite games! I want to say right away that the game will run on all devices: Windows, Linux, macOS (Intel/Apple)! The Dalam World client features advanced graphics that will look great! The client also provides stable FPS even with a huge number of players! Dalam World is not a Salve or Chronicle client ported upward — it’s a completely remade game on its own proprietary game engine! Dalam World servers allow more than 100,000 people to exist in a single world without virtual instances, thanks to server technologies built with Elixir and Rust! Dalam World is the childhood game we love so much! From each of our favorite MMOs we took only the best elements! Low system requirements will let the game run on an old laptop! We redesigned the game so there are no bots or real-money traders! Game website: https://Dalam.World Game forum: https://Dalam.World/forums/ For arbitragers: https://careers.dalam.world/ Discord: https://discord.gg/vbQ347nuxd Telegram: https://t.me/+u1DNZPzscaRmNjYx Opening July 16, 2026 at 16:00 UTC!  
  • Topics

×
×
  • Create New...

Important Information

This community uses essential cookies to function properly. Non-essential cookies and third-party services are used only with your consent. Read our Privacy Policy and We have placed cookies on your device to help make this website better. You can adjust your cookie settings, otherwise we'll assume you're okay to continue..