Matter.jsは、JavaScriptに記載されている2D Rigid Body Physics Engineです。このライブラリは、ブラウザで2D物理学を簡単にシミュレートするのに役立ちます。剛体を作成し、質量、面積、密度などの物理的特性を割り当てる機能など、多くの機能を提供します。また、重力摩擦など、さまざまな種類の衝突や力をシミュレートすることもできます。
Matter.jsは、すべての主流ブラウザをサポートしています。さらに、タッチを検出し、応答性が高いため、モバイルデバイスに適しています。これらの機能はすべて、物理ベースの2Dゲームまたはシミュレーションを簡単に作成できるため、エンジンの使用方法を学ぶために時間をかける価値があります。このチュートリアルでは、このライブラリのインストールや使用法を含むこのライブラリの基本を取り上げ、実行可能な例を提供します。
インストール
NPMのようなパッケージマネージャーを使用して、次のコマンドでmatter.jsをインストールできます。
npm install matter-jsCDNからライブラリへのリンクを取得して、このようにプロジェクトに直接含めることもできます。
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.jsで作成され、 メソッドを使用してランナーとレンダラーを実行する必要があります。これは基本的に、Matter.jsの世界で作成およびレンダリングするために必要なすべてのコードです。
この投稿は、Monty Shokeenからの貢献により更新されました。 Montyはフルスタック開発者であり、チュートリアルの作成や新しいJavaScriptライブラリの学習も大好きです。 engine
キーがあります。また、オブジェクトをその値として実際に受け入れるoptions
キーもあります。このキーを使用して、キャンバスのwidth
やheight
などのさまざまなパラメーターの値を設定できます。また、wireframe
キーの値をそれぞれtrue
またはfalse
に設定することにより、ワイヤフレームをオンまたはオフにすることもできます。また、背景の価値を白に設定することにより、私たちの世界のキャンバスの色を白にします。 Matter.Bodies
モジュールを使用します。この例では、2つの円と長方形を作成するには、circle()
およびrectangle()
メソッドのみを使用します。他の方法を使用して、異なるポリゴンを作成することもできます。 Matter.Composite
add()
このセクションの先頭にあるコードは、次の結果を作成します。 run()
前のセクションの例では、4つの異なるモジュールを使用して、レンダリング、シミュレーション、およびオブジェクトの作成を処理します。このセクションでは、Matter.jsで一般的に使用されるいくつかのモジュールの役割について学びます。
このチュートリアルは、Matter.jsライブラリを紹介することを目的としています。これを念頭に置いて、ライブラリの機能とインストールの概要を簡単に説明しました。 2つの円と正方形を含む基本的な例は、ライブラリを使用して簡単なシミュレーションを作成するのがどれほど簡単かを示しています。 Engine
モジュールは、異なるエンジンの動作を制御できるさまざまな方法とプロパティを提供します。 Bodies
モジュールには、円、長方形、台形などの一般的な形状を持つ剛体を作成するのに役立つさまざまな方法が含まれています。 Body
Bodies
Composites
Composite
Composite
Composites
制約
Matter.jsには多くのモジュールがあり、それぞれがエンジンに独自のアプローチを追加しているため、いくつかの一般的なモジュールの簡単な要約をすでに作成しました。このシリーズの残りの部分は、これらの一般的に使用されるモジュールをより詳細に説明することに焦点を当てます。
以上がMatter.jsを始めましょう:はじめにの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

私はあなたの日常的な技術ツールを使用して機能的なマルチテナントSaaSアプリケーション(EDTECHアプリ)を作成しましたが、あなたは同じことをすることができます。 まず、マルチテナントSaaSアプリケーションとは何ですか? マルチテナントSaaSアプリケーションを使用すると、Singの複数の顧客にサービスを提供できます

この記事では、許可によって保護されたバックエンドとのフロントエンド統合を示し、next.jsを使用して機能的なedtech SaaSアプリケーションを構築します。 FrontEndはユーザーのアクセス許可を取得してUIの可視性を制御し、APIリクエストがロールベースに付着することを保証します

JavaScriptは、現代のWeb開発のコア言語であり、その多様性と柔軟性に広く使用されています。 1)フロントエンド開発:DOM操作と最新のフレームワーク(React、Vue.JS、Angularなど)を通じて、動的なWebページとシングルページアプリケーションを構築します。 2)サーバー側の開発:node.jsは、非ブロッキングI/Oモデルを使用して、高い並行性とリアルタイムアプリケーションを処理します。 3)モバイルおよびデスクトップアプリケーション開発:クロスプラットフォーム開発は、反応および電子を通じて実現され、開発効率を向上させます。

JavaScriptの最新トレンドには、TypeScriptの台頭、最新のフレームワークとライブラリの人気、WebAssemblyの適用が含まれます。将来の見通しは、より強力なタイプシステム、サーバー側のJavaScriptの開発、人工知能と機械学習の拡大、およびIoTおよびEDGEコンピューティングの可能性をカバーしています。

JavaScriptは現代のWeb開発の基礎であり、その主な機能には、イベント駆動型のプログラミング、動的コンテンツ生成、非同期プログラミングが含まれます。 1)イベント駆動型プログラミングにより、Webページはユーザー操作に応じて動的に変更できます。 2)動的コンテンツ生成により、条件に応じてページコンテンツを調整できます。 3)非同期プログラミングにより、ユーザーインターフェイスがブロックされないようにします。 JavaScriptは、Webインタラクション、シングルページアプリケーション、サーバー側の開発で広く使用されており、ユーザーエクスペリエンスとクロスプラットフォーム開発の柔軟性を大幅に改善しています。

Pythonはデータサイエンスや機械学習により適していますが、JavaScriptはフロントエンドとフルスタックの開発により適しています。 1. Pythonは、簡潔な構文とリッチライブラリエコシステムで知られており、データ分析とWeb開発に適しています。 2。JavaScriptは、フロントエンド開発の中核です。 node.jsはサーバー側のプログラミングをサポートしており、フルスタック開発に適しています。

JavaScriptは、最新のブラウザにすでに組み込まれているため、インストールを必要としません。開始するには、テキストエディターとブラウザのみが必要です。 1)ブラウザ環境では、タグを介してHTMLファイルを埋め込んで実行します。 2)node.js環境では、node.jsをダウンロードしてインストールした後、コマンドラインを介してJavaScriptファイルを実行します。

Quartzタイマーを使用してタスクをスケジュールする場合、Quartzでタスク通知を事前に送信する方法、タスクの実行時間はCron式によって設定されます。今...


ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

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

SAP NetWeaver Server Adapter for Eclipse
Eclipse を SAP NetWeaver アプリケーション サーバーと統合します。

EditPlus 中国語クラック版
サイズが小さく、構文の強調表示、コード プロンプト機能はサポートされていません

Dreamweaver Mac版
ビジュアル Web 開発ツール

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境
