


Detailed explanation of code examples for getting started with HTML5 canvas (picture)
1) HTMLCanvasElement Members of object :
# #height——corresponds to the height attribute of the canvas element;
##width—— Corresponds to the width attribute of the canvas element;
# getContext(
##2) Draw the rectangle:
## fillRect(x,y,w,h)——Draw a solid rectangle;# strokeRect(x,y,w,h)——Draw a hollow rectangle;
clear
Rect(x,y,w,h)——Clear the specified rectangle;canvas{
border:medium double black;
margin: 4px;
}
body > *{
float: left;
}
<canvas id="canvas1" width="500" height="200">
您的浏览器不支持<code>canvas</code>!
</canvas>
<script>
//绘制矩形
var ctx=document.getElementById("canvas1").getContext("2d");
//ctx.fillRect(10,10,50,50);
var offset=10;
var size=50;
var count=5;
for(var i=0;i<count;i++){
ctx.fillRect(i*(offset+size)+offset,offset,size,size);
ctx.strokeRect(i*(offset+size)+offset,(2*offset)+size,size,size);
ctx.clearRect(i*(offset+size)+offset,offset+5,size,size-10);
}
</script>
3) Set canvas drawing status:
li neWidth——Get or set the width of the line (default value is 1.0);
lineJoin——Get or set The style when the line is connected to the graphic (default value is miter);
fillStyle——Get or set for solid The style of the graphic (default value is black);
strokeStyle - Gets or sets the style used for lines (default value is black );
# <canvas id="canvas2" width="500" height="70">
您的浏览器不支持<code>canvas</code>!
</canvas>
<script>
//在执行操作前绘制设置状态
var ctx=document.getElementById("canvas2").getContext("2d");
ctx.lineWidth=2;
ctx.strokeRect(10,10,50,50);
ctx.lineWidth=4;
ctx.strokeRect(70,10,50,50);
ctx.lineWidth=6;
ctx.strokeRect(130,10,50,50);
ctx.lineWidth=8;
ctx.strokeRect(200,10,50,50);
</script>
<canvas id="canvas3" width="500" height="140">
您的浏览器不支持<code>canvas</code>!
</canvas>
<script>
//设置lineJoin属性
var ctx=document.getElementById("canvas3").getContext("2d");
ctx.lineWidth=20;
ctx.lineJoin="round";
ctx.strokeRect(20,20,100,100);
ctx.lineJoin="bevel";
ctx.strokeRect(160,20,100,100);
ctx.lineJoin="miter";
ctx.strokeRect(300,20,100,100);
</script>
<canvas id="canvas4" width="500" height="140"> 您的浏览器不支持<code>canvas</code>! </canvas>
<script> //设置填充和笔触样式 var ctx=document.getElementById("canvas4").getContext("2d"); var offset=10; var size=50; var count=5; var lineWidth=3; var fillColors=["black","grey","lightgrey","red","blue"]; var strokeColors=["rgb(0,0,0)","rgb(100,100,100)","rgb(200,200,200)","rgb(255,0,0)","rgb(0,0,255)"]; for(var i=0;i<count;i++){ ctx.fillStyle=fillColors[i]; ctx.strokeStyle=strokeColors[i]; ctx.fillRect(i*(offset+size)+offset,offset,size,size); ctx.strokeRect(i*(offset+size)+offset,(2*offset)+size,size,size); } </script>

4) Use gradient
createRadialGradient(x0,y0,r0,x1,y1,r1 )——Create a radial gradient and return a CanvasGradient object;
CanvasGradient object
Methods: ## addColorStop(position>,
## <canvas id="canvas5" width="500" height="140">
您的浏览器不支持<code>canvas</code>!
</canvas>
rrree
<canvas id="canvas6" width="500" height="140"> 您的浏览器不支持<code>canvas</code>! </canvas>
<script> //使用径向渐变 var ctx=document.getElementById("canvas6").getContext("2d"); var grad=ctx.createRadialGradient(250,70,20,200,60,100); grad.addColorStop(0,"red"); grad.addColorStop(0.5,"white"); grad.addColorStop(1,"black"); ctx.fillStyle=grad; ctx.fillRect(0,0,500,140); </script>
<canvas id="canvas7" width="500" style="max-width:90%"> 您的浏览器不支持<code>canvas</code>! </canvas>
<script> //使用较小的图形和径向渐变 var ctx=document.getElementById("canvas7").getContext("2d"); var grad=ctx.createRadialGradient(250,70,20,200,60,100); grad.addColorStop(0,"red"); grad.addColorStop(0.5,"white"); grad.addColorStop(1,"black"); ctx.fillStyle=grad; ctx.fillRect(150,20,75,50); ctx.lineWidth=8; ctx.strokeStyle=grad; ctx.strokeRect(250,20,75,50); </script>
5)使用图案
createPattern(,int2)——创建图案,指定图案文件的来源和重复方式;
int2的值是指定重复样式:分别有repeat、repeat-x、repeat-y、no-repeat;
<canvas id="canvas8" width="500" height="150"> 您的浏览器不支持<code>canvas</code>! </canvas> <img src="/static/imghwm/default1.png" data-src="images/banana-small.png" class="lazy" id="banana" hidden / alt="Detailed explanation of code examples for getting started with HTML5 canvas (picture)" >
<script> //使用图像类的图案 var ctx=document.getElementById("canvas8").getContext("2d"); var imageElem=document.getElementById("banana"); var pattern=ctx.createPattern(imageElem,"repeat"); ctx.fillStyle=pattern; ctx.fillRect(0,0,500,148); </script>
6)保存和恢复状态
save()——保存绘制状态属性的值,并把它们推入状态栈;
restore()——取出状态栈的第一组值,用它们来设置绘制状态;
<canvas id="canvas9" width="500" height="150" preload="auto"> 您的浏览器不支持<code>canvas</code>! </canvas> <p> <button>Save</button> <button>Restore</button> </p>
<script> //保存和恢复状态 var ctx=document.getElementById("canvas9").getContext("2d"); var grad=ctx.createLinearGradient(500,0,500,140); grad.addColorStop(0,"red"); grad.addColorStop(0.5,"white"); grad.addColorStop(1,"black"); var colors=["black",grad,"red","green","yellow","black","grey"]; var cIndex=0; ctx.fillStyle=colors[cIndex]; draw(); var buttons=document.getElementsByTagName("button"); for(var i=0;i<buttons.length;i++){ buttons[i].onclick=handleButtonPress; } function handleButtonPress(e){ switch(e.target.innerHTML){ case 'Save': ctx.save(); cIndex=(cIndex+1)%colors.length; ctx.fillStyle=colors[cIndex]; draw(); break; case 'Restore': cIndex=Math.max(0,cIndex-1); ctx.restore(); draw(); break; } } function draw(){ ctx.fillRect(0,0,500,140); } </script>
7)绘制图像
drawImage方法——在画布上绘制图像,指定一个img、canvas或video元素作为来源;
<canvas id="canvas10" width="500" height="150" preload="auto"> 您的浏览器不支持<code>canvas</code>! </canvas> <img src="/static/imghwm/default1.png" data-src="images/banana-small.png" class="lazy" id="banana2" hidden / alt="Detailed explanation of code examples for getting started with HTML5 canvas (picture)" >
<script> //使用drawImage方法 var ctx2=document.getElementById("canvas10").getContext("2d"); var imageElement=document.getElementById("banana2"); ctx2.drawImage(imageElement,10,10); ctx2.drawImage(imageElement,120,10,100,120); ctx2.drawImage(imageElement,20,20,100,50,250,10,100,120); </script>
<video id="vid" src="raw/timessquare.webm" controls preload="auto" width="360" style="max-width:90%"> 您的浏览器不支持; </video> <canvas id="canvas11" width="360" height="240"> 您的浏览器不支持; </canvas> <p> <button id="pressme">Snapshot</button> <button id="pressme2">PressMe</button> </p> <canvas id="canvas12" width="360" height="240"> 您的浏览器不支持; </canvas>
<script> //使用视频作为drawImage方法的来源 var ctx3=document.getElementById("canvas11").getContext("2d"); var imageElement3=document.getElementById("vid"); document.getElementById("pressme").onclick=function(e){ ctx3.drawImage(imageElement3,0,0,360,240); } var width=100; var height=10; ctx3.lineWidth=5; ctx3.strokeStyle="red"; setInterval(function(){ ctx3.drawImage(imageElement3,0,0,360,240); ctx3.strokeRect(180-(width/2),120-(height/2),width,height); },25); setInterval(function(){ width=(width-1)%200; height=(height+3)%200; },100); </script> <script> //将画布作为drawImage方法的来源 var srcCanvasElement=document.getElementById("canvas11"); var ctx4=srcCanvasElement.getContext("2d"); var ctx5=document.getElementById("canvas12").getContext("2d"); var imageElement4=document.getElementById("vid"); document.getElementById("pressme2").onclick=takeSnapshot; var width=100; var height=10; ctx4.lineWidth=5; ctx4.strokeStyle="red"; ctx5.lineWidth=30; ctx5.strokeStyle="black"; setInterval(function(){ ctx4.drawImage(imageElement4,0,0,360,240); ctx4.strokeRect(180-(width/2),120-(height/2),width,height); },25); setInterval(function(){ width=(width+1)%200; height=(height+3)%200; },100); function takeSnapshot(){ ctx5.drawImage(srcCanvasElement,0,0,360,240); ctx5.strokeRect(0,0,360,240); } </script>
The above is the detailed content of Detailed explanation of code examples for getting started with HTML5 canvas (picture). For more information, please follow other related articles on the PHP Chinese website!

The methods of building a website in HTML5 include: 1. Use semantic tags to define the web page structure, such as, , etc.; 2. Embed multimedia content, use and tags; 3. Apply advanced functions such as form verification and local storage. Through these steps, you can create a modern web page with clear structure and rich features.

A reasonable H5 code structure allows the page to stand out among a lot of content. 1) Use semantic labels such as, etc. to organize content to make the structure clear. 2) Control the rendering effect of pages on different devices through CSS layout such as Flexbox or Grid. 3) Implement responsive design to ensure that the page adapts to different screen sizes.

The main differences between HTML5 (H5) and older versions of HTML include: 1) H5 introduces semantic tags, 2) supports multimedia content, and 3) provides offline storage functions. H5 enhances the functionality and expressiveness of web pages through new tags and APIs, such as and tags, improving user experience and SEO effects, but need to pay attention to compatibility issues.

The difference between H5 and HTML5 is: 1) HTML5 is a web page standard that defines structure and content; 2) H5 is a mobile web application based on HTML5, suitable for rapid development and marketing.

The core features of HTML5 include semantic tags, multimedia support, form enhancement, offline storage and local storage. 1. Semantic tags such as, improve code readability and SEO effect. 2. Multimedia support simplifies the process of embedding media content through and tags. 3. Form Enhancement introduces new input types and verification properties, simplifying form development. 4. Offline storage and local storage improve web page performance and user experience through ApplicationCache and localStorage.

HTML5isamajorrevisionoftheHTMLstandardthatrevolutionizeswebdevelopmentbyintroducingnewsemanticelementsandcapabilities.1)ItenhancescodereadabilityandSEOwithelementslike,,,and.2)HTML5enablesricher,interactiveexperienceswithoutplugins,allowingdirectembe

Advanced tips for H5 include: 1. Use complex graphics to draw, 2. Use WebWorkers to improve performance, 3. Enhance user experience through WebStorage, 4. Implement responsive design, 5. Use WebRTC to achieve real-time communication, 6. Perform performance optimization and best practices. These tips help developers build more dynamic, interactive and efficient web applications.

H5 (HTML5) will improve web content and design through new elements and APIs. 1) H5 enhances semantic tagging and multimedia support. 2) It introduces Canvas and SVG, enriching web design. 3) H5 works by extending HTML functionality through new tags and APIs. 4) Basic usage includes creating graphics using it, and advanced usage involves WebStorageAPI. 5) Developers need to pay attention to browser compatibility and performance optimization.


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Dreamweaver Mac version
Visual web development tools

WebStorm Mac version
Useful JavaScript development tools

Dreamweaver CS6
Visual web development tools

SublimeText3 English version
Recommended: Win version, supports code prompts!

MinGW - Minimalist GNU for Windows
This project is in the process of being migrated to osdn.net/projects/mingw, you can continue to follow us there. MinGW: A native Windows port of the GNU Compiler Collection (GCC), freely distributable import libraries and header files for building native Windows applications; includes extensions to the MSVC runtime to support C99 functionality. All MinGW software can run on 64-bit Windows platforms.
