1
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 1 year has passed since last update.

Babylon.jsAdvent Calendar 2023

Day 4

Babylon.js で作成したメッシュの頂点を編集する方法

Posted at

これはBabylon.js Advent Calendar 2023 の4日目の記事です。

この記事について

Babylon.jsでは、BABYLON.MeshBuilderで立方体や球体を表示します。
今回はここで生成したメッシュの頂点を、調整する方法について記述します。

作成した立方体の頂点を取得する

Playgroundを開いて、下記のように立方体を1つ作成するコードを記述します。

立方体を表示
    var box = BABYLON.MeshBuilder.CreateBox("box1", {width: 2, height: 2, depth: 2}, scene);

baby20231204_1.png
https://playground.babylonjs.com/#UY72D0

立方体を表示したら、下記のようにgetVerticesDataでメッシュの頂点データを配列で取得できます。

立方体の頂点を取得
    var boxpos = box.getVerticesData(BABYLON.VertexBuffer.PositionKind);
    alert(boxpos);

お手軽にalertで取得した内容を表示してみます。
baby20231204_2.png
取得した各頂点毎のXYZ座標が連続で表示されました。1点につきXYZ座標があるので、3つの値で1つの頂点に相当します。
今回作成した立方体は、中心座標が0、XYZのサイズが2なので、XYZ座標がすべて1と-1になっていますね。

頂点を編集する

頂点を編集するには、CreateBoxで立方体を作成する際にオプションで「updatable:true」を記述して編集を許可しておく必要があります。(これを忘れると変更した内容が反映されずに悩みます)

編集可能な立方体を表示
   var box = BABYLON.MeshBuilder.CreateBox("box1", {width: 2, height: 2, depth: 2, updatable:true}, scene);

編集可能にした立方体の頂点をgetVerticesDataで取得したら、その配列を編集します。必要な編集が終わったら、updateVerticesDataで立方体に変更した頂点位置を反映します。

1つの頂点位置(XYZ)を2.5倍する
    //頂点の値を変更
    boxpos[0] = boxpos[0] * 2.5;
    boxpos[1] = boxpos[1] * 2.5;
    boxpos[2] = boxpos[2] * 2.5;
    //変更した頂点を反映する
    box.updateVerticesData(BABYLON.VertexBuffer.PositionKind, boxpos);

baby20231204_3.png
https://playground.babylonjs.com/#UY72D0#1

立方体のうち、1点の頂点を移動することができました。

最期に

今回は作成した立方体の頂点を編集する方法について記述しました。
色々と応用ができるので、いくつか色々試してみようと思います。

1
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
1
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?