Heim > Web-Frontend > H5-Tutorial > Hauptteil

HTML5-Zeichnungsbilder (Teil 1): Probleme mit dem Canvas-Element, die die nächste Generation von Webseiten leiten_html5-Tutorial-Fähigkeiten

WBOY
Freigeben: 2016-05-16 15:49:28
Original
1309 Leute haben es durchsucht
Erste Einführung in das Canvas-Element

HTML5 fügt ein neues Element Canvas hinzu, das zum Zeichnen verwendet wird. Tatsächlich kommt seine Leistung der von div relativ nahe (tatsächlich sollte es zum Inline-Block gehören) und bietet viele Schnittstellen zum einfachen Zeichnen von Rechtecken Kästen, Gartendreiecke usw.

PS: Zu den neuen Elementen von HTML5
经过最近两天的学习,和以前对HTML5的认知,我认为HTML5其实还是HTML4,两者之间没多大的区别,无非是增加了点新东西。<br />我认为HTML5为我们带来的真正意义是:我们可以用javascript做更多的事情了;我们可以用javascript实现更好的产品了。比如HTML5就解决了我们头疼的跨域问题、实时通信API、与现在的canvas之所以HTML5叫HTML5,我认为他是划时代的,比如他让我们用网页开发游戏变成可能;比如他让电脑桌面只剩IE不在是传说(过于夸张)
Nach dem Login kopieren
Zeichnen Sie einen rechteckigen Rahmen

Kommen wir gleich zur Sache, zeichnen wir ein rechteckiges Feld und werfen einen Blick darauf. Hier ist ein Farbwähler zur bequemen Farbauswahl. PS: Es fühlt sich jetzt wirklich mühsam an, keine JQuery-Programmierung zu verwenden. . .

Frage: Stil definieren und Höhe und Breite definieren

Ich bin sofort auf ein Problem gestoßen, als ich hierher kam:

Kopieren Sie den Code
Der Code lautet wie folgt:



canvas id="canvas" width=300 height="200" style="border: 1px solid black; width: 300px; height: 200px;"> > /html>




Jeder kennt das Canvas-Element. Abbildung 1 zeigt den Fall, in dem Breite und Höhe festgelegt werden, und Abbildung 20 zeigt den Fall, in dem der Stil angegeben wird:




Wie Sie sehen, ist es bei Leinwand besser, die Höhe und Breite ehrlich zu definieren und Stile nicht töricht zu verwenden. Natürlich erfordert dieses Problem tatsächliche Recherche, um die endgültige Schlussfolgerung zu ziehen.

Okay, jetzt schauen wir uns an, wie man ein Rechteck zeichnet:







An diesem Punkt endet das Zeichnen des rechteckigen Rahmens.



Zeichne einen Kreis

Apropos Zeichnen eines Kreises, ich habe tatsächlich einen mit js geschrieben. Ich werde ihn auch hier posten:

Kopieren Sie den Code

Der Code lautet wie folgt:
PS:其实,使用该方法这么麻烦,完全可以将该函数封装下下,使用便会简单许多
Nach dem Login kopieren

我是纯js画的圆














话说,他还是比较圆的说。。。

进入正题

说起画圆、正弦图等肯定会经过一定计算的,所以稍稍复杂点:

① 创建路径

② 创建图形路径

③ 路径创建完成后关闭路径

④ 🎜>


我是一个圆















我们来看看绘制圆过程中其它地方都没有问题,但是创建圆路径这块值得考虑:

arc方法参数很多,依次是:xy半径开始弧度(我们一般喜欢角度,所以要转换)结束弧度顺时针或者逆时针true为顺时针<br />其它都好说,主要这个开始角度和结束角度我们来研究下,因为开始我没搞懂,但后来我发现他其实很简单了。。。就是开始的角度和结束的角度嘛,和我们高中学的知识一样的,只不过单位换算Math.PI/180为一度。。。。<br />反正还是没说清楚,对了,记得我们高中画圆的除了圆规和一个计量三角形角度的半圆直尺了吗,我要说的角度就是那个。。。太坑爹了!<br />好像最右边是0度,垂直是90度,水平是180度,既然如此,我们再来看看<br /><br><div class="msgheader"><div class="right"><span style="CURSOR: pointer" onclick="copycode(getid('phpcode20'));"><u>复制代码</u></span></div>代码如下:</div><div class="msgborder" id="phpcode20"><br /> 正时针逆时针 <br /> <!DOCTYPE html><br /> <html xmlns="http://www.w3.org/1999/xhtml"><br /> <head><br />     <title></title><br />     <script type="text/javascript"><br />         function draw() {<br />             //获取canvas对象<br />             var canvas = document.getElementById('canvas');<br />             if (canvas == null) {<br />                 return false;<br />             }<br />             var context = canvas.getContext('2d');<br />             context.fillStyle = '#99d9ea';<br />             context.fillRect(0, 0, 400, 300); //填充画布结束<br /> <br />             context.beginPath();<br />             context.arc(80, 80, 50, 0, 180 * Math.PI / 180, true);<br />             context.closePath();<br />             context.fillStyle = 'gray';<br />             context.fill();<br /> <br />             context.beginPath();<br />             context.arc(180, 180, 50, 0, 180 * Math.PI / 180, false);<br />             context.closePath();<br />             context.fillStyle = 'gray';<br />             context.fill();<br /> <br /> <br />         }<br />     </script><br /> </head><br /> <body><br />     <canvas id="canvas" width="400" height="300"><br />     </canvas><br />     <br />     <button onclick="draw();"><br />         绘制圆</button><br />     <input type="color" /><br /> </body><br /> </html><br /> </div><br /><p><img alt="" src="http://files.jb51.net/file_images/article/201304/2013042416135933.jpg" /></p><p>我们发现正时针与逆时针还是有所不同的,</p><div class="cnblogs_code"><pre class="brush:php;toolbar:false"> context.arc(180, 180, 50, 90 * Math.PI / 180, 290 * Math.PI / 180, true);
Nach dem Login kopieren

原谅我这里居然思考了半个小时,我甚至搜索了高中的资料。。。。

于是我好像明白了点什么。。。。。。

moveTo与lineTo

现上实验结果:

复制代码
代码如下:

两次moveto
















复制代码
代码如下:

一次moveto
















复制代码
代码如下:

三次moveto















以上代码几乎一样,但是他产生的结果却不同:

我认为,使用moveto后相当于新开一起点,之前的一笔勾销,若是只使用lineto的话,他会将几个点连成线,若是可以组成图形便会拥有中间色彩
Nach dem Login kopieren
Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage