【Processing】modelX()、modelY()、modelZ()の使い方【複数の3Dオブジェクトを正確に配置したり、特定の変換後の位置を使って他のオブジェクトを配置することができる】

【Processing】modelX()、modelY()、modelZ()の使い方
  • URLをコピーしました!
ワタタク

今回の記事の目的はProcessingの「modelX()」を理解し、自分なりに使ってみること。

この記事を書いた人

ワタタク(Watataku)
  • クリエイティブコーダー / アーティスト
  • 「人の心に寄り添う、機能するアート」を探究しています
  • アートとテクノロジーが、社会や個人のウェルビーイングにどう貢献できるかに、関心があります

記事内のProcessingのバージョンは4.3。

目次

【Processing】modelX()、modelY()、modelZ()について

modelX()、modelY()、modelZ()について
  • 複数の3Dオブジェクトを正確に配置したり、特定の変換後の位置を使って他のオブジェクトを配置することができる

【Processing】modelX()、modelY()、modelZ()の使い方【画像とコード】

Processingリファレンスのhttps://processing.org/reference/modelX_.html に載っていたサンプルをそのままに、日本語のコメントを載せています。

初期の位置 (0, 0, 0)
↓ modelX, modelY, modelZ によって取得された変換後の位置
変換された位置 (x, y, z)
↓ その位置を基準に新しいオブジェクトを配置

void setup() {
  size(500, 500, P3D); // 画面サイズを500x500ピクセルに設定し、3Dモードを有効にする
  noFill(); // 図形の内部を塗りつぶさない設定
}

void draw() {
  background(0); // 背景を黒にする

  pushMatrix(); // 現在の変換行列を保存する
  // 画面の中央に移動
  translate(width/2, height/2, -200);  
  // 立方体を少しずつ回転させる
  rotateX(frameCount * 0.01); 
  rotateY(frameCount * 0.01);

  // (0, 0, 0)の位置に白い立方体の枠を描画する
  stroke(255); // 線の色を白に設定
  box(100); // 辺の長さが100の立方体を描く

  // 立方体が描かれた位置を保存する
  float x = modelX(0, 0, 0);
  float y = modelY(0, 0, 0);
  float z = modelZ(0, 0, 0);
  // すべての変換をクリアする
  popMatrix();

  // 前の立方体と同じ(x, y, z)座標に新しい立方体を描く
  pushMatrix(); // 新しい変換を保存する
  translate(x, y, z); // 立方体の位置に移動
  stroke(255, 0, 0); // 線の色を赤に設定
  box(100); // 辺の長さが100の立方体を描く
  popMatrix(); // 変換をクリアする
}

【Processing】modelX()、modelY()、modelZ()を使ってみた感想

難しい。

ワタタク

それでは今日もレッツワクワクコーディング。

ワタタク(Watataku)
クリエイティブコーダー/アーティスト
AIと共に、「人の心に寄り添う、機能するアート」を探究しています。

ここは、その思索と創造の全記録を記す、思考の実験室(アトリエ)です。

僕の創作の源泉は、人生経験そのものです。
不当な出来事や、精神的な支配の中で、私の心は何度も粉々に砕け散りました。しかし、その一つ一つの破片をどのようにすれば鮮やかな絵の具にできるかを考え、ゆっくり心のパレットに色を整えていきました。その、長い、長い、自身との対話の果てに「人の役に立つアートを作りたい」という考え方にたどり着きました。

かつて、僕の武器は、アコースティックギター弾き語りと、カメラでした。
オリジナルソングの演奏でお客様投票1位となった「物語の力」。
世界20カ国の旅で培った、多様な「視点」。

今、僕は、それら全ての経験を、「コード」という、新しい言語で、世界に問いかけています。

このブログでは、作品の制作過程や、日々の発見、そして、僕自身の上達の軌跡を記録していきます。

僕の旅が、あなたの日常を、ほんの少しでも豊かにするための、光になることを願って。

クリエイティブコーディングロード運営者 ワタタク
よかったらシェアしてね!
  • URLをコピーしました!
  • URLをコピーしました!
目次