data:image/s3,"s3://crabby-images/c2aa5/c2aa5fcf888db754885222b0237fe9eb86274069" alt=""
data:image/s3,"s3://crabby-images/a5263/a5263b8cf4aacf3830e94cde1c301827683388c7" alt=""
ノードネットワーク
data:image/s3,"s3://crabby-images/15e78/15e78e7ae18d9b765d7148fcd357e0429f70e1f9" alt=""
左側はポリライン、右側が断面のポリライン。それぞれUVの、UとVの値を記録しておいて、Sweep SOPでメッシュ化した後、WrangleでUVを整理する流れ。
UV Texture SOP
data:image/s3,"s3://crabby-images/5d976/5d9768ed4e01dd54c66baaddf26bc6a56ffc7436" alt=""
Texture Type をArc Length Splineにする。Attribute ClassはPointに。
Scaleにarclen(0, 0, 0, 1)と入力。
arclen(0, 0, 0, 1)
引数は左から、ノード、プリミティブ番号、Uの開始値、Uの終了値。U値がワールド空間でのカーブの長さで保存される。
calc_uv_width (Point Wrangle)
断面カーブに正規化した各エッジの長さ(座標)を格納する。
data:image/s3,"s3://crabby-images/fbec7/fbec711341e6fc92b5a2f089134471c7d1a9a83f" alt=""
//
// UVのuを長さの割合で0-1に収める
// RunOver: Detail
//
float length[];
float sum = 0;
for(int i = 1; i < npoints(0); i++)
{
vector p0 = point(0, "P", i-1);
vector p1 = point(0, "P", i);
length[i] = length(p1 - p0);
sum += length[i];
}
for(int i = 1; i < npoints(0); i++)
{
length[i] /= sum;
}
sum = 1;
for(int i = 0; i < npoints(0); i++)
{
sum -= length[i];
setpointattrib(0, "__x", i, sum);
}
reset_uv (Point Wrangle)
data:image/s3,"s3://crabby-images/f8fcf/f8fcf8dab114647ad90c5c0d632279be8eaeba3c" alt=""
断面方向には0-1のスケールでUVが設定され、進行方向には実際の長さの値が設定されている。
int uRepeat = 1; // u方向のリピート数
float uvStep = 1; // テクスチャ一枚を進行方向に何メートルで貼るか
@uv.y = @uv.x; // 実際のメートルの値になっている
@uv.x = f@__x;
// UVの幅はリピート数
@uv.x *= uRepeat;
@uv.y /= uvStep;
data:image/s3,"s3://crabby-images/80296/802966c698fbc45c1274ae45898f3c425c985d22" alt=""
V方向に伸びるように再構築している。
data:image/s3,"s3://crabby-images/c2aa5/c2aa5fcf888db754885222b0237fe9eb86274069" alt=""