【Processing】windowRatio()の使い方【ウィンドウの幅と高さの比率を計算する】

【Processing】windowRatio()の使い方【ウィンドウの幅と高さの比率を計算する】
  • URLをコピーしました!
ワタタク

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

この記事を書いた人

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

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

目次

【Processing】windowRatio()について

  • “window”は「窓」、”ratio”は「比率」。つまり「窓の比率」という意味
  • windowRatio() は、ウィンドウの幅を高さで割った比率を計算する関数です。これを使うと、ウィンドウの形状に応じて表示内容を調整する
    • 画面の中の絵が歪まないようにしたり、レイアウトが崩れないようにすることができる

【Processing】windowRatio()の使い方【画像とコード】

【Processing】windowRatio()の使い方【画像とコード】
// ウィンドウの比率を計算する関数
float windowRatio() {
  // ウィンドウの幅を高さで割った値を返す
  return (float) width / height;
}

void setup() {
  // 初期設定、キャンバスサイズを設定
  size(400, 300);
}

void draw() {
  // 背景を白に設定
  background(255);

  // ウィンドウの比率を計算
  float ratio = windowRatio();

  // スケーリング
  pushMatrix();
  scale(ratio, 1); // ウィンドウの比率に基づいてスケーリング

  // 比率に応じて円の大きさを変える
  ellipse(mouseX / ratio, mouseY, 50, 50); // スケーリングされた座標に円を描く
  
  popMatrix();
}

void mouseMoved() {
  // スケーリングされた mouseX と mouseY
  float scaledMouseX = mouseX / windowRatio();
  float scaledMouseY = mouseY;

  // スケーリングされたマウス座標を使う処理
  println("Scaled Mouse X: " + scaledMouseX + ", Scaled Mouse Y: " + scaledMouseY);
}

void mousePressed() {
  // スケーリングされた座標を使った例
  float scaledMouseX = mouseX / windowRatio();
  float scaledMouseY = mouseY;

  println("Mouse pressed at: " + scaledMouseX + ", " + scaledMouseY);
}

【Processing】windowRatio()を使ってみた感想

画像をつかった作品をつくるときにwindowRatio()を使う可能性がある。

ワタタク

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

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

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

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

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

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

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

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

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