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.

 

 

 

 

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.
Note: Your post will require moderator approval before it will be visible.

Guest
Reply to this topic...

×   Pasted as rich text.   Paste as plain text instead

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.



  • Posts

    • Faltan demasiados archivos,  y lógicas en clases claves como L2pcInstance, entre otras. si bien muchas cosas están y el flujo es valorable.  Gracias por tu esfuerzo es bastante... pero realmente no esta completo el código, falta que subas todas las modificaciones en clases colaterales... podrías intentar subir un diff de todo el mod  completo de tu pack y bueno ahí si que cada uno adapte... pero faltan muchas cosas, dudo que haya gente que lo haya echo funcionar con esto... 
    • I know people who have fully bypassed and reversed AAC. One day, they might even release the full source code, but for now, they’re still making money off it. I won’t name anyone, but it’s clear that there aren’t any truly solid anticheats for Lineage2. As I’ve said before, kernel level anticheats are the only real solution. Anything that runs as Internal and injects gets flagged, and your account ends up getting kicked or banned. That’s just how most games handle it nowadays. To TL;DR the whole thing cheating will always exist because there are people out there smart enough to bypass any protection and run private cheats. Public cheats are always detected eventually, so I don’t see any point in buying AAC, especially when they claim it blocks adr, which simply isn’t true.
    • 🌐 Website: https://l2adonis.com 📅 GRAND OPENING: July 18, 2025 – 20:00 (UTC+2) 💬 Discord: https://discord.com/invite/tZBj8JxAwx 🚫 No auto-farm • No auto-macro • No pay-to-win • No custom   Some Basic Info's (More detalied info's on website)  EXP/SP: x25  Adena: x15  Drop: x15  Spoil: x15  Seal Stones: x15  Raid Boss Drop: x10  Epic Boss Drop: x1  Manor: x10  Safe Enchant: +4  Max Enchant: +16  Normal Scroll Chance: 50%  Blessed Scroll Chance: 66% (If enchant fail item remain +4)  Buff Slots (30+4 extra with Divine Inspiration)  Dances/Songs Slots 14  Auto-learn skills  ⚔️ Real PvP • Real Progression • Retail-like experience JOIN NOW and relive the real L2 experience!
    • Discord         :  utchiha_market Telegram        : https://t.me/utchiha_market Auto Buy Store  : https://utchihamkt.mysellauth.com/ Not sure if we’re legit? Check Our server — real reviews, real buyers https://discord.gg/uthciha-servicess  | https://campsite.bio/utchihaamkt
    • Looking for a Developer – Lineage II Interlude (Vanganth Files)   I’m seeking a developer to collaborate on a project based on Vanganth Interlude files.   Important: Applicants with a bad attitude, lack of respect, or unwillingness to work will be immediately rejected. Payment: Hourly rate, not per task. Contact: Please reach out to me via PM.
  • Topics

×
×
  • Create New...

AdBlock Extension Detected!

Our website is made possible by displaying online advertisements to our members.

Please disable AdBlock browser extension first, to be able to use our community.

I've Disabled AdBlock