検索

Getting Started With Matter.js: Introduction

Matter.jsは、JavaScriptに記載されている2D Rigid Body Physics Engineです。このライブラリは、ブラウザで2D物理学を簡単にシミュレートするのに役立ちます。剛体を作成し、質量、面積、密度などの物理的特性を割り当てる機能など、多くの機能を提供します。また、重力摩擦など、さまざまな種類の衝突や力をシミュレートすることもできます。

Matter.jsは、すべての主流ブラウザをサポートしています。さらに、タッチを検出し、応答性が高いため、モバイルデバイスに適しています。これらの機能はすべて、物理ベースの2Dゲームまたはシミュレーションを簡単に作成できるため、エンジンの使用方法を学ぶために時間をかける価値があります。このチュートリアルでは、このライブラリのインストールや使用法を含むこのライブラリの基本を取り上げ、実行可能な例を提供します。

インストール

NPMのようなパッケージマネージャーを使用して、次のコマンドでmatter.jsをインストールできます。

npm install matter-js
CDNからライブラリへのリンクを取得して、このようにプロジェクトに直接含めることもできます。

Matter.jsは頻繁に更新を公開します。これには、コードを適切に機能させるために、コードにいくつかの小さな変更が必要になる場合があります。このチュートリアルの例は、バージョン0.18.0に基づいています。
<!-- CDN链接 -->

基本的な例

最初に、プロジェクトで必要とされるすべてのMatter.jsモジュールのエイリアスを作成します。

const Engine = Matter.Engine,
    Render = Matter.Render,
    Runner = Matter.Runner,
    Bodies = Matter.Bodies,
    Composite = Matter.Composite;

const iEngine = Engine.create();
const iRunner = Runner.create();

const iRender = Render.create({
  element: document.body,
  engine: iEngine,
  options: {
    width: 800,
    height: 400,
    wireframes: false,
    background: "white"
  }
});

const boxA = Bodies.rectangle(400, 200, 80, 80);
const ballA = Bodies.circle(380, 100, 40, 10);
const ballB = Bodies.circle(460, 10, 40, 10);
const ground = Bodies.rectangle(400, 380, 810, 60, { isStatic: true });

Composite.add(iEngine.world, [boxA, ballA, ballB, ground]);

Render.run(iRender);

Runner.run(iRunner, iEngine);
Matter.Runnerモジュールを使用すると、エンジンと世界への継続的な更新のためにゲームループにアクセスできます。

Matter.comPositeモジュールを使用すると、オブジェクトのコレクション、制約、またはその他の複合オブジェクトを作成できます。複合体には、単一のオブジェクトまたはシミュレーション全体を含めることができます。

次の行では、

モジュールの

メソッドを使用して新しいエンジンを作成します。同様に、新しいランナーと新しいレンダラーも作成しました。上記のメソッドの

パラメーターは、実際には、エンジンに関連する特定のプロパティのデフォルト値を上書きするキー値ペアオブジェクトです。この例では、すべてをデフォルトとして残しました。 Matter.Engine たとえば、create([settings])世界のすべてのオブジェクトのグローバルタイムスケーリング係数を制御できます。値を1未満に設定すると、世界はスローモーションで相互作用します。同様に、1を超える値は世界を速くします。このシリーズの次のチュートリアルでは、settingsモジュールの詳細について詳しく説明します。

の後、Matter.Engineモジュールの

メソッドを使用して、新しいレンダラーを作成します。エンジンモジュールと同様に、上記の方法の設定パラメーターは、パラメーターのさまざまなオプションを指定するオブジェクトです。

キーを使用して、ライブラリがキャンバスに挿入する要素を指定できます。同様に、Matter.Render

レンダリングの世界に適用するエンジンを指定するために使用できるengineキーがあります。また、オブジェクトをその値として実際に受け入れるoptionsキーもあります。このキーを使用して、キャンバスのwidthheightなどのさまざまなパラメーターの値を設定できます。また、wireframeキーの値をそれぞれtrueまたはfalseに設定することにより、ワイヤフレームをオンまたはオフにすることもできます。また、背景の価値を白に設定することにより、私たちの世界のキャンバスの色を白にします。

次の数行は、私たちの世界で相互作用する異なるオブジェクトを作成します。これらのオブジェクトは、matter.jsで作成され、Matter.Bodiesモジュールを使用します。この例では、2つの円と長方形を作成するには、circle()およびrectangle()メソッドのみを使用します。他の方法を使用して、異なるポリゴンを作成することもできます。

オブジェクトを作成した後、オブジェクトを選択した世界に追加する必要があります。必要なオブジェクトを私たちの世界に追加した後、それぞれのモジュールで

メソッドを使用してランナーとレンダラーを実行する必要があります。これは基本的に、Matter.jsの世界で作成およびレンダリングするために必要なすべてのコードです。 Matter.Composite add()このセクションの先頭にあるコードは、次の結果を作成します。 run()

Matter.jsには20以上の異なるモジュールがあります。これらのすべてのモジュールは、さまざまな種類のシミュレーションを作成するのに役立ち、それらと対話できるさまざまな方法とプロパティを提供します。これらのモジュールの中には衝突を処理するものもあれば、レンダリングとシミュレーションを処理するモジュールもあります。

前のセクションの例では、4つの異なるモジュールを使用して、レンダリング、シミュレーション、およびオブジェクトの作成を処理します。このセクションでは、Matter.jsで一般的に使用されるいくつかのモジュールの役割について学びます。

  • エンジン:Matter.js Worldのシミュレーションを更新するには、エンジンが必要です。 Engineモジュールは、異なるエンジンの動作を制御できるさまざまな方法とプロパティを提供します。
  • render:ユーザーがシミュレーションで見ることができる実際のオブジェクトを作成するには、レンダラーが必要です。それを使用して、エルフなどをサポートする基本的なゲームを開発できます。
  • ランナー:あなたがシミュレートするあらゆる世界のオブジェクトは、常に相互に対話します。ランナーモジュールは、これらの継続的な更新をエンジンと世界に処理します。
  • Bodiesモジュールには、円、長方形、台形などの一般的な形状を持つ剛体を作成するのに役立つさまざまな方法が含まれています。
  • Body :このモジュールは、Bodiesモジュールで利用可能な方法とプロパティについてのみ説明します。 Body
  • composites モジュールと同様に、このモジュールには、共通の構成を持つコンポジットオブジェクトを作成するために使用できるさまざまな方法が含まれています。たとえば、モジュールに単一の方法を使用して、長方形のボックスのスタックまたはピラミッドを作成できます。 Bodies Composites
  • composite
  • モジュールには、複合オブジェクトを作成および操作できるさまざまな方法とプロパティがあります。このシリーズの4番目のチュートリアルでは、およびモジュールの詳細を読むことができます。 Composite CompositeComposites制約
  • :このモジュールを使用すると、制約を作成および操作できます。制約を使用して、2つのオブジェクトまたは固定されたワールドスペースポイントとオブジェクトが固定距離に保持されるようにすることができます。これは、補強を介して2つのオブジェクトを接続することに似ています。これらの制約の剛性を変更して、ロッドがスプリングのようになり始めるようにすることができます。 Matter.jsは、Newtonian PendulumまたはChain Complexを作成するときに制約を使用します。
  • mouseconstraint
  • :このモジュールは、マウスの制約を作成および操作できるさまざまな方法とプロパティを提供します。これは、世界のさまざまなオブジェクトがユーザーと対話したい場合に役立ちます。
  • 最終的な考え
このチュートリアルは、Matter.jsライブラリを紹介することを目的としています。これを念頭に置いて、ライブラリの機能とインストールの概要を簡単に説明しました。 2つの円と正方形を含む基本的な例は、ライブラリを使用して簡単なシミュレーションを作成するのがどれほど簡単かを示しています。

Matter.jsには多くのモジュールがあり、それぞれがエンジンに独自のアプローチを追加しているため、いくつかの一般的なモジュールの簡単な要約をすでに作成しました。このシリーズの残りの部分は、これらの一般的に使用されるモジュールをより詳細に説明することに焦点を当てます。

この投稿は、Monty Shokeenからの貢献により更新されました。 Montyはフルスタック開発者であり、チュートリアルの作成や新しいJavaScriptライブラリの学習も大好きです。

以上がMatter.jsを始めましょう:はじめにの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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

PythonまたはJavaScriptの選択は、キャリア開発、学習曲線、エコシステムに基づいている必要があります。1)キャリア開発:Pythonはデータサイエンスとバックエンド開発に適していますが、JavaScriptはフロントエンドおよびフルスタック開発に適しています。 2)学習曲線:Python構文は簡潔で初心者に適しています。 JavaScriptの構文は柔軟です。 3)エコシステム:Pythonには豊富な科学コンピューティングライブラリがあり、JavaScriptには強力なフロントエンドフレームワークがあります。

JavaScriptフレームワーク:最新のWeb開発のパワーJavaScriptフレームワーク:最新のWeb開発のパワーMay 02, 2025 am 12:04 AM

JavaScriptフレームワークのパワーは、開発を簡素化し、ユーザーエクスペリエンスとアプリケーションのパフォーマンスを向上させることにあります。フレームワークを選択するときは、次のことを検討してください。1。プロジェクトのサイズと複雑さ、2。チームエクスペリエンス、3。エコシステムとコミュニティサポート。

JavaScript、C、およびブラウザの関係JavaScript、C、およびブラウザの関係May 01, 2025 am 12:06 AM

はじめに私はあなたがそれを奇妙に思うかもしれないことを知っています、JavaScript、C、およびブラウザは正確に何をしなければなりませんか?彼らは無関係であるように見えますが、実際、彼らは現代のウェブ開発において非常に重要な役割を果たしています。今日は、これら3つの間の密接なつながりについて説明します。この記事を通して、JavaScriptがブラウザでどのように実行されるか、ブラウザエンジンでのCの役割、およびそれらが協力してWebページのレンダリングと相互作用を駆動する方法を学びます。私たちは皆、JavaScriptとブラウザの関係を知っています。 JavaScriptは、フロントエンド開発のコア言語です。ブラウザで直接実行され、Webページが鮮明で興味深いものになります。なぜJavascrを疑問に思ったことがありますか

node.jsは、型を使用してストリーミングしますnode.jsは、型を使用してストリーミングしますApr 30, 2025 am 08:22 AM

node.jsは、主にストリームのおかげで、効率的なI/Oで優れています。 ストリームはデータを段階的に処理し、メモリの過負荷を回避します。大きなファイル、ネットワークタスク、リアルタイムアプリケーションの場合。ストリームとTypeScriptのタイプの安全性を組み合わせることで、パワーが作成されます

Python vs. JavaScript:パフォーマンスと効率の考慮事項Python vs. JavaScript:パフォーマンスと効率の考慮事項Apr 30, 2025 am 12:08 AM

PythonとJavaScriptのパフォーマンスと効率の違いは、主に以下に反映されています。1)解釈された言語として、Pythonはゆっくりと実行されますが、開発効率が高く、迅速なプロトタイプ開発に適しています。 2)JavaScriptはブラウザ内の単一のスレッドに限定されていますが、マルチスレッドおよび非同期I/Oを使用してnode.jsのパフォーマンスを改善でき、両方とも実際のプロジェクトで利点があります。

JavaScriptの起源:その実装言語の調査JavaScriptの起源:その実装言語の調査Apr 29, 2025 am 12:51 AM

JavaScriptは1995年に発信され、Brandon Ikeによって作成され、言語をCに実現しました。 2。JavaScriptのメモリ管理とパフォーマンスの最適化は、C言語に依存しています。 3. C言語のクロスプラットフォーム機能は、さまざまなオペレーティングシステムでJavaScriptを効率的に実行するのに役立ちます。

舞台裏:JavaScriptをパワーする言語は何ですか?舞台裏:JavaScriptをパワーする言語は何ですか?Apr 28, 2025 am 12:01 AM

JavaScriptはブラウザとnode.js環境で実行され、JavaScriptエンジンに依存してコードを解析および実行します。 1)解析段階で抽象的構文ツリー(AST)を生成します。 2)ASTをコンパイル段階のバイトコードまたはマシンコードに変換します。 3)実行段階でコンパイルされたコードを実行します。

PythonとJavaScriptの未来:傾向と予測PythonとJavaScriptの未来:傾向と予測Apr 27, 2025 am 12:21 AM

PythonとJavaScriptの将来の傾向には、1。Pythonが科学コンピューティングの分野での位置を統合し、AI、2。JavaScriptはWebテクノロジーの開発を促進します。どちらもそれぞれのフィールドでアプリケーションシナリオを拡大し続け、パフォーマンスをより多くのブレークスルーを行います。

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 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

DVWA

DVWA

Damn Vulnerable Web App (DVWA) は、非常に脆弱な PHP/MySQL Web アプリケーションです。その主な目的は、セキュリティ専門家が法的環境でスキルとツールをテストするのに役立ち、Web 開発者が Web アプリケーションを保護するプロセスをより深く理解できるようにし、教師/生徒が教室環境で Web アプリケーションを教え/学習できるようにすることです。安全。 DVWA の目標は、シンプルでわかりやすいインターフェイスを通じて、さまざまな難易度で最も一般的な Web 脆弱性のいくつかを実践することです。このソフトウェアは、

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

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

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

VSCode Windows 64 ビットのダウンロード

VSCode Windows 64 ビットのダウンロード

Microsoft によって発売された無料で強力な IDE エディター

Dreamweaver Mac版

Dreamweaver Mac版

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)