検索
ホームページウェブフロントエンドhtmlチュートリアルHTML5 Canvas游戏开发(一)基础知识 - suvllian

  一、绘制基本图形

  在每次用canvas画布时,都有几步是“套路”

  1.在HTML中创建Canvas画布:

<span style="color: #0000ff;"><span style="color: #800000;">canvas </span><span style="color: #ff0000;">id</span><span style="color: #0000ff;">="mycanvas"</span><span style="color: #ff0000;"> width</span><span style="color: #0000ff;">="960px"</span><span style="color: #ff0000;"> height</span><span style="color: #0000ff;">="580px"</span><span style="color: #0000ff;">></span><span style="color: #000000;">
    浏览器不支持canvas   </span><span style="color: #008000;"><!--</span><span style="color: #008000;"> 如果不支持会显示这段文字 </span><span style="color: #008000;">--></span>
<span style="color: #0000ff;"></span><span style="color: #800000;">canvas</span><span style="color: #0000ff;">></span></span>

  2.获取画布标签,并得到一个2D对象:

<span style="color: #0000ff;">var</span> c = document.getElementById('mycanvas');  <span style="color: #008000;">//</span><span style="color: #008000;">获取标签</span>
<span style="color: #0000ff;">var</span> ctx = c.getContext("2d");   <span style="color: #008000;">//</span><span style="color: #008000;">返回一个用来绘制环境类型的环境,返回一个2D对象 ,该对象实现了一个画布使用的大多数方法。</span>

  1、绘制线条:

ctx.lineWidth = 10;    <span style="color: #008000;">//</span><span style="color: #008000;">设置线条宽度   </span>
ctx.strokeStyle = "red";  <span style="color: #008000;">//</span><span style="color: #008000;">设置线条的颜色</span>
ctx.beginPath();    <span style="color: #008000;">//</span><span style="color: #008000;">创建一个新的路径</span>
ctx.moveTo(10,10);      <span style="color: #008000;">//</span><span style="color: #008000;">将画笔光标位置移动到坐标(10,10)处</span>
ctx.lineTo(150,10);    <span style="color: #008000;">//</span><span style="color: #008000;">移动画笔到坐标(150,50)处</span>
ctx.stroke();          <span style="color: #008000;">//</span><span style="color: #008000;">开始绘制定义好的路径</span>

  通过ctx.lineCap="butt"可以设置线条的形状。有三个可取值:butt、round、square。

  2、绘制空心矩形:

md5.strokeRect(100,100,200,240);   <span style="color: #008000;">//</span><span style="color: #008000;">绘制空心矩形的函数,四个参数分别表示起点X、Y坐标、矩形长、矩形宽</span>

  3、绘制实心矩形:

  方法一:使用fillRext()函数。在绘制实心矩形时,可使用fillStyle设置图形的颜色。

  方法二:

md5.rect(10,10,70,40<span style="color: #000000;">);
md5.fill();</span>

  4、画圆:

  使用arc()函数可以画一个圆弧。有六个参数:圆弧中心X、Y坐标、圆弧半径、起始角度、终

止角度、是否逆时针。可以调用fill()函数画一个实心圆。

  5、画圆角矩形:

  用arcTo函数可以画圆角矩形。有五个参数:P1的X、Y和P2的X、Y、圆弧的半径radius。

  6、擦除Canvas画板:

  clearRect()函数。四个参数:X、Y、长度、宽度。

  7、绘制复杂:二维贝塞尔曲线、三维贝塞尔曲线。

  8、利用clip()函数可在指定区域绘图。

  9、绘制自定义图形。

  二、绘制文本 

  1、cxt.font:设置字体样式。

ctx.font = "30px Arial";    <span style="color: #008000;">//</span><span style="color: #008000;">设置文字大小和字体样式、字体大小、斜体效果</span>

  2、cxt.strokeText():设置文字内容。空心文字!有四个参数:文本字符串,坐标X、坐标Y、文本宽 。最后一个参数可以省去,省去时文本宽度自动设定为整个文本的宽度。

ctx.strokeText("Hello World",100,50);   <span style="color: #008000;">//</span><span style="color: #008000;">设置文字内容</span>

  3、cxt.fillText():设置文字内容。实心文字!参数同strokeText();

  4、ctx.textAlign=" ";设置文字对齐方式:center、left、right。

  5、ctx.textBaseline=" "; 设置文字纵向对齐方式:top、middle、bottom、ideographic等。

  三、图片操作

  1、利用drawImage()函数绘制图片,该函数有三种原型:

<span style="color: #000000;">drawImage(image,dx,dy);
drawImage(image,dx,dy,dw,dh);
drawImage(image,sx,sy,sw,sh,dx,dydw,dh);</span>

  第一参数都是要绘制的对象。

  绘制图像方法一:

  在HTML添加如下代码:

<span style="color: #0000ff;"><span style="color: #800000;">img </span><span style="color: #ff0000;">id</span><span style="color: #0000ff;">="face"</span><span style="color: #ff0000;"> src</span><span style="color: #0000ff;">="1.jpg"</span><span style="color: #ff0000;"> alt</span><span style="color: #0000ff;">="the face"</span><span style="color: #ff0000;"> width</span><span style="color: #0000ff;">="240px"</span><span style="color: #ff0000;"> height</span><span style="color: #0000ff;">="240px"</span><span style="color: #0000ff;">></span></span>

  JavaScript代码如下:

<span style="color: #0000ff;">var</span> img=document.getElementById("face"<span style="color: #000000;">);
image.onload </span>=<span style="color: #0000ff;">function</span><span style="color: #000000;">(){
        ctx.drawImage(image,</span>10,10<span style="color: #000000;">);
    }  </span>

  绘制图像方法二:

<span style="color: #0000ff;">var</span> image = <span style="color: #0000ff;">new</span><span style="color: #000000;"> Image();
    image.src </span>= "1.jpg"<span style="color: #000000;">;
    image.onload </span>=<span style="color: #0000ff;">function</span><span style="color: #000000;">(){
        ctx.drawImage(image,</span>10,10<span style="color: #000000;">);
        ctx.drawImage(image,</span>260,10,100,100<span style="color: #000000;">);
        ctx.drawImage(image,</span>50,50,100,100,260,130,100,100<span style="color: #000000;">);
    } </span>

  一定要添加图片的onload事件监听!

  第一个函数从(10,10)开始绘制整张图片。

  第二个函数从(260,10)绘制整张图片到长100、宽100的矩形区域内。

  第三个函数表示截取图片从(50,50)到(100,100)的部分,从坐标(260,130)开始绘制,放到长100、宽100的矩形区域内。

  2、利用getImageData和putImageData绘制图片。

  3、利用createImageData新建像素。

 

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
HTMLタグとHTML属性の違いは何ですか?HTMLタグとHTML属性の違いは何ですか?May 14, 2025 am 12:01 AM

htmltagsdeTheStructureOfawebpage、whiLeattributesdddddddddtetails.1)tagslike、andoutlineThecontentのsplacement.2)属性、クラス、およびスチリーンハンシテアグビーズイメージソース、スタイリング、および改善、および改善の想像力。

HTMLの未来:進化とトレンドHTMLの未来:進化とトレンドMay 13, 2025 am 12:01 AM

HTMLの未来は、よりセマンティック、機能的、モジュール式方向に発展します。 1)セマンティック化により、タグがコンテンツをより明確に説明し、SEOとバリアのないアクセスを改善します。 2)機能化は、ユーザーのニーズを満たすために新しい要素と属性を導入します。 3)モジュール性は、コンポーネントの開発をサポートし、コードの再利用性を改善します。

Web開発にとってHTML属性が重要なのはなぜですか?Web開発にとってHTML属性が重要なのはなぜですか?May 12, 2025 am 12:01 AM

htmlattributesarecrucialinwebdevevermentmentmentmentmentmentmentmention behavior、like、andfunctionality.theyenhance -interactivity、accessibility、andseo.forexample、thesrcattribute intagsimpactsseo

Alt属性の目的は何ですか?なぜそれが重要なのですか?Alt属性の目的は何ですか?なぜそれが重要なのですか?May 11, 2025 am 12:01 AM

ALT属性は、HTMLのタグの重要な部分であり、画像の代替テキストを提供するために使用されます。 1.画像をロードできない場合、ALT属性のテキストが表示され、ユーザーエクスペリエンスが向上します。 2。スクリーンリーダーは、ALT属性を使用して、視覚障害のあるユーザーが写真の内容を理解するのに役立ちます。 3. ALT属性のEnginesインデックステキストを検索して、WebページのSEOランキングを改善します。

HTML、CSS、およびJavaScript:例と実用的なアプリケーションHTML、CSS、およびJavaScript:例と実用的なアプリケーションMay 09, 2025 am 12:01 AM

Web開発におけるHTML、CSS、およびJavaScriptの役割は次のとおりです。1。HTMLは、Webページ構造の構築に使用されます。 2。CSSは、Webページの外観を美化するために使用されます。 3. JavaScriptは、動的な相互作用を実現するために使用されます。タグ、スタイル、スクリプトを通じて、これら3つは最新のWebページのコア関数を構築します。

Lang属性をタグにどのように設定しますか?なぜこれが重要なのですか?Lang属性をタグにどのように設定しますか?なぜこれが重要なのですか?May 08, 2025 am 12:03 AM

タグのLang属性を設定することは、WebアクセシビリティとSEOを最適化する重要なステップです。 1)ラング属性をタグに設定します。 2)多言語コンテンツでは、ようなさまざまな言語パーツのLang属性を設定します。 3)「EN」、「FR」、「ZH」などのISO639-1標準に準拠する言語コードを使用します。Lang属性を正しく設定すると、Webページと検索エンジンランキングのアクセシビリティが向上します。

HTML属性の目的は何ですか?HTML属性の目的は何ですか?May 07, 2025 am 12:01 AM

htmlattributeSareSientionalentionalentionalentionalentiallyance'functionalityandappearance.theyaddinformationtodefinebehavior、light、and interaction、makewebsitesteractive、responsive、andviseallyappaleal.attributeslikesrc、href、class、型、およびdoadabledransform

HTMLでリストを作成するにはどうすればよいですか?HTMLでリストを作成するにはどうすればよいですか?May 06, 2025 am 12:01 AM

toreatealistinhtml、useforunorderedlistsandfororderedlists:1)forunorderedlists、wrapitemsinanduseforeachitem、renderingasabulletedlist.2)

See all articles

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

AtomエディタMac版ダウンロード

AtomエディタMac版ダウンロード

最も人気のあるオープンソースエディター

SublimeText3 英語版

SublimeText3 英語版

推奨: Win バージョン、コードプロンプトをサポート!

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

mPDF

mPDF

mPDF は、UTF-8 でエンコードされた HTML から PDF ファイルを生成できる PHP ライブラリです。オリジナルの作者である Ian Back は、Web サイトから「オンザフライ」で PDF ファイルを出力し、さまざまな言語を処理するために mPDF を作成しました。 HTML2FPDF などのオリジナルのスクリプトよりも遅く、Unicode フォントを使用すると生成されるファイルが大きくなりますが、CSS スタイルなどをサポートし、多くの機能強化が施されています。 RTL (アラビア語とヘブライ語) や CJK (中国語、日本語、韓国語) を含むほぼすべての言語をサポートします。ネストされたブロックレベル要素 (P、DIV など) をサポートします。

Dreamweaver Mac版

Dreamweaver Mac版

ビジュアル Web 開発ツール