Difference between revisions of "LlRotTarget/ja"
Jump to navigation
Jump to search
Mako Nozaki (talk | contribs) m |
|||
(One intermediate revision by one other user not shown) | |||
Line 7: | Line 7: | ||
|func_footnote=同じような関数が位置についてもあります: {{LSLG/ja|llTarget}}<br/>この関数はオブジェクトを回転させません。回転させるには、{{LSLG/ja|llSetRot}} 、{{LSLG/ja|llRotLookAt}} 、{{LSLG/ja|llLookAt}} を使用してください。 | |func_footnote=同じような関数が位置についてもあります: {{LSLG/ja|llTarget}}<br/>この関数はオブジェクトを回転させません。回転させるには、{{LSLG/ja|llSetRot}} 、{{LSLG/ja|llRotLookAt}} 、{{LSLG/ja|llLookAt}} を使用してください。 | ||
|func_desc=この関数で、ある回転に到達したときに、スクリプトにそれを知らせることができます。<br/>'''rot''' を '''error''' と一緒に登録し、登録解除されるまで {{LSLG/ja|at_rot_target}} や {{LSLG/ja|not_at_rot_target}} を継続的に発生させます。 | |func_desc=この関数で、ある回転に到達したときに、スクリプトにそれを知らせることができます。<br/>'''rot''' を '''error''' と一緒に登録し、登録解除されるまで {{LSLG/ja|at_rot_target}} や {{LSLG/ja|not_at_rot_target}} を継続的に発生させます。 | ||
|return_text={{LSLG/ja|llRotTargetRemove}} | |return_text={{LSLG/ja|llRotTargetRemove}} を使って目標を登録解除するためのハンドラ | ||
|spec | |spec | ||
|caveats | |caveats | ||
|constants | |constants | ||
|examples= | |examples= | ||
< | <source lang="lsl2"> | ||
vector standrot = <0.0, 0.0, 0.0>; | vector standrot = <0.0, 0.0, 0.0>; | ||
vector fliprot = <45.0, 0.0, 0.0>; | vector fliprot = <45.0, 0.0, 0.0>; | ||
Line 62: | Line 62: | ||
} | } | ||
</ | </source> | ||
|helpers | |helpers | ||
|also_tests | |also_tests |
Latest revision as of 12:43, 25 February 2016
LSL ポータル | 関数 | イベント | 型 | 演算子 | 定数 | 実行制御 | スクリプトライブラリ | カテゴリ別スクリプトライブラリ | チュートリアル |
要約
関数: integer llRotTarget( rotation rot, float error );
この関数で、ある回転に到達したときに、スクリプトにそれを知らせることができます。
rot を error と一緒に登録し、登録解除されるまで at_rot_target や not_at_rot_target を継続的に発生させます。
llRotTargetRemove を使って目標を登録解除するためのハンドラを integer で返します。
• rotation | rot | – | 目標とする回転 | |
• float | error | – | rot に到達したか決める角度誤差をラジアンで |
同じような関数が位置についてもあります: llTarget
この関数はオブジェクトを回転させません。回転させるには、llSetRot 、llRotLookAt 、llLookAt を使用してください。
サンプル
vector standrot = <0.0, 0.0, 0.0>;
vector fliprot = <45.0, 0.0, 0.0>;
// Hypatia Callisto 作の、簡単な 2 個のステートからなる回転検知と回転
// 作動すると、目標回転を検知します。
// at_rot_target, not_at_rot_target, llRotTarget, llRotTargetRemove
// の純粋なサンプルがほとんどなかったので、サンプルを書きました。
integer rottarget;
default
{
state_entry(){
rottarget = llRotTarget(llEuler2Rot(fliprot*DEG_TO_RAD), 0.1);
llSetPrimitiveParams ([PRIM_ROTATION, llEuler2Rot(standrot*DEG_TO_RAD)]); // 最初の回転位置まで回転する
}
not_at_rot_target()
{
llRotTargetRemove( rottarget );
llOwnerSay("not there"); //目標ではない
}
touch_start (integer total_number)
{
state rotatestate; // ステートを切り替えて、新しい位置に
}
}
state rotatestate
{
state_entry(){
rottarget = llRotTarget(llEuler2Rot(fliprot*DEG_TO_RAD), 0.1);
llSetPrimitiveParams ([PRIM_ROTATION, llEuler2Rot(fliprot*DEG_TO_RAD)]); // 新しい回転位置まで回転する
}
at_rot_target(integer tnum, rotation targetrot, rotation ourrot)
{
llRotTargetRemove( rottarget );
llOwnerSay("there"); //目標に到達
}
touch_start(integer touched){
state default;
}
}
関連項目
イベント
• at_rot_target | not_at_rot_target | – | 回転目標に達したときのイベント | |
• at_target | not_at_target | – | 位置目標に達したときのイベント |
関数
• | llRotTargetRemove | – | 回転目標を登録解除します | |
• | llTarget | – | 位置目標を登録します | |
• | llTargetRemove | – | 位置目標を登録解除します |
特記事項
この項目はあなたにとって参考にならない項目ですか?もしかしたらLSL Wikiの関連した項目が参考になるかもしれません。