【Processing】curveTangent()の使い方【曲線上の任意の点における接線の傾きを計算するために使う】

【Processing】curveTangent()の使い方【曲線上の任意の点における接線の傾きを計算するために使う】
  • URLをコピーしました!
ワタタク

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

この記事を書いた人

クリエイティブコーダー Watataku のプロフィール写真
ワタタク(Watataku)

上達の研究家 / アーティスト

「才能」ではなく「論理(システム)」で、人の心を動かす機能するアートを探究中

【文系・36歳・未経験】から独学でクリエイティブコーディングに挑戦し、独自の思考法で以下の実績を達成

  • 開始1年8ヶ月目までに公募6つに挑戦し、3つ入選(勝率50%)
  • 開始1年9ヶ月目に、虎ノ門ヒルズ ステーションタワー49階 スカイガーデン&プールのために制作した作品が展示される

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

目次

【Processing】curveTangent()について

curveTangent()について
  • Curveは「曲線」、Tangentは「接線」という意味です。つまり、「曲線の接線」という意味になる
  • curveTangent()は、Processingで使われる関数の一つで、曲線上の任意の点における接線の傾きを計算するために使う

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

// 画面サイズを設定
size(400, 400);

// 図形の塗りを無効にする
noFill();

// 背景色を白に設定
background(255);

// 曲線の制御ポイントを設定 (始点, 制御点1, 制御点2, 終点)
curve(100, 200, 150, 50, 250, 350, 300, 100);

// 曲線を描く際の分割数 (ステップ数)
int steps = 6;

// ループを用いて曲線上の接線を描く
for (int i = 0; i <= steps; i++) {
  // tは曲線上の位置 (0から1まで)
  float t = i / float(steps);
  
  // 曲線上の点のx座標を計算
  float x = curvePoint(100, 150, 250, 300, t);
  
  // 曲線上の点のy座標を計算
  float y = curvePoint(200, 50, 350, 100, t);
  
  // タンジェントのx成分を計算 (接線の傾き)
  float tx = curveTangent(100, 150, 250, 300, t);
  
  // タンジェントのy成分を計算 (接線の傾き)
  float ty = curveTangent(200, 50, 350, 100, t);
  
  // 接線の傾きから角度を計算
  float a = atan2(ty, tx);
  
  // 接線の方向を90度回転 (垂直にする)
  a -= PI/2.0;
  
  // 接線を描画
  line(x, y, cos(a) * 32 + x, sin(a) * 32 + y);
}

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

曲線に線がつくのは面白い。

ワタタク

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

ワタタク(Watataku)
上達の研究家
アナログ絵画(2025.11~) × クリエイティブコーディング(2024.3~)

「不完全な人間(Analog)」が、「完全な論理(Algorithm)」を武器にどこまで行けるか。

手描きの一本の線(One)をコードで無限(All)に拡張し、再び一つの作品へ定着させる。「才能」ではなく「発見」と「システム」で描く、人生をかけた実験記録。

溢れる思考を、独自の脳内OS「Watataku Blueprint」で整理し、初心者から世界で活躍するまでの「激闘」と「攻略本」を公開しています。

▼【創作×上達】思考を「作品」に変える、モレスキン6冊の運用設計図
よかったらシェアしてね!
  • URLをコピーしました!
  • URLをコピーしました!
目次