Difference between revisions of "LlEuler2Rot/ja"
Jump to navigation
Jump to search
Mako Nozaki (talk | contribs) m (Undo revision 850402 by Mako Nozaki (Talk)) |
Mako Nozaki (talk | contribs) |
||
Line 4: | Line 4: | ||
|func_footnote | |func_footnote | ||
|func_desc | |func_desc | ||
|return_text=オイラー角'''v''' | |return_text=オイラー角 '''v''' | ||
|spec= | |spec=オイラー角ベクトル (単位はラジアン) は Z, Y, X の順に 3 つの軸のまわりを回転し、回転に変換されます。このため、llEuler2Rot(<1.0, 2.0, 3.0> * DEG_TO_RAD) は回転を生成するのに、X 軸のポインティング・ベクトルをとり、最初にグローバルの Z 軸まわりに 3° 回転させ、次にできたベクトルを Y 軸まわりに 2° 回転させ、最後に X 軸まわりに 1° 回転させます。 | ||
|caveats | |caveats | ||
|constants | |constants | ||
Line 12: | Line 12: | ||
state_entry() | state_entry() | ||
{ | { | ||
vector input = <73.0, -63.0, 20.0> * DEG_TO_RAD; | vector input = <73.0, -63.0, 20.0> * DEG_TO_RAD; | ||
rotation rot = llEuler2Rot(input); | rotation rot = llEuler2Rot(input); | ||
llSay(0,"The Euler2Rot of "+(string)input+" is: "+(string)rot ); | llSay(0,"The Euler2Rot of "+(string)input+" is: "+(string)rot ); | ||
Line 18: | Line 18: | ||
}</lsl> | }</lsl> | ||
|helpers | |helpers | ||
|also_functions={{LSL DefineRow|| | |also_functions={{LSL DefineRow||{{LSLG/ja|llRot2Euler}}|}} | ||
|also_events | |also_events | ||
|also_tests | |also_tests | ||
|also_articles={{LSL DefineRow||{{Wikipedia| | |also_articles={{LSL DefineRow||{{Wikipedia|オイラー角|lang=ja}}|}} | ||
|notes=<lsl>v/=2; | |notes=<lsl>v/=2; | ||
rotation k = <0.0, 0.0, llSin(v.z), llCos(v.z)> * <0.0, llSin(v.y), 0.0, llCos(v.y)> * <llSin(v.x), 0.0, 0.0, llCos(v.x)>;</lsl> | rotation k = <0.0, 0.0, llSin(v.z), llCos(v.z)> * <0.0, llSin(v.y), 0.0, llCos(v.y)> * <llSin(v.x), 0.0, 0.0, llCos(v.x)>;</lsl> |
Revision as of 23:24, 2 May 2010
LSL ポータル | 関数 | イベント | 型 | 演算子 | 定数 | 実行制御 | スクリプトライブラリ | カテゴリ別スクリプトライブラリ | チュートリアル |
要約
関数: rotation llEuler2Rot( vector v );仕様
オイラー角ベクトル (単位はラジアン) は Z, Y, X の順に 3 つの軸のまわりを回転し、回転に変換されます。このため、llEuler2Rot(<1.0, 2.0, 3.0> * DEG_TO_RAD) は回転を生成するのに、X 軸のポインティング・ベクトルをとり、最初にグローバルの Z 軸まわりに 3° 回転させ、次にできたベクトルを Y 軸まわりに 2° 回転させ、最後に X 軸まわりに 1° 回転させます。
サンプル
<lsl>default {
state_entry() { vector input = <73.0, -63.0, 20.0> * DEG_TO_RAD; rotation rot = llEuler2Rot(input); llSay(0,"The Euler2Rot of "+(string)input+" is: "+(string)rot ); }}</lsl>
注意点
<lsl>v/=2; rotation k = <0.0, 0.0, llSin(v.z), llCos(v.z)> * <0.0, llSin(v.y), 0.0, llCos(v.y)> * <llSin(v.x), 0.0, 0.0, llCos(v.x)>;</lsl>
関連項目
特記事項
この項目はあなたにとって参考にならない項目ですか?もしかしたらLSL Wikiの関連した項目が参考になるかもしれません。