Difference between revisions of "LlGetClosestNavPoint/ja"

From Second Life Wiki
Jump to navigation Jump to search
m
m
Line 2: Line 2:
|inject-2={{LSL_Function/position|point|region=*}}
|inject-2={{LSL_Function/position|point|region=*}}
|func=llGetClosestNavPoint
|func=llGetClosestNavPoint
|func_desc=Used to get a point on the navmesh that is the closest point to {{LSLP|point}}.
|func_desc={{LSLP|point}}に最も近いナビメッシュ上のポイントを取得するために使用されます。
|func_sleep_frame=1
|func_sleep_frame=1
|return_type=list
|return_type=list
|return_text=containing a single vector which is the closest point on the navmesh to the point provided or an empty list.
|return_text={{LSLP|point}}に最も近いナビメッシュ上のポイントを含む単一のベクトル、または空のリスト。
|func_footer=If an option is not explicitly set, the default value for that option is used.
|func_footer=オプションが明示的に設定されていない場合、そのオプションのデフォルト値が使用されます。
|p1_type=vector|p1_name=point
|p1_type=vector|p1_name=point
|p2_type=list|p2_subtype=instructions|p2_name=options
|p2_type=list|p2_subtype=instructions|p2_name=options
|p2_desc=GCNP_* and other flags with their parameters. See [[#Options|options]] table
|p2_desc=GCNP_* およびその他のフラグとそれに対するパラメータ。[[#Options|options]]テーブルを参照してください。
|constants={{LSL Constants/llGetClosestNavPoint}}
|constants={{LSL Constants/llGetClosestNavPoint/ja}}
|caveats=
|caveats=
* There is no guarantee that a path exists from your current location to the returned point.
* 現在の位置から返されたポイントまでの経路が存在することを保証するものではありません。
|examples=
|examples=
<source lang="lsl2">
<source lang="lsl2">

Revision as of 10:59, 22 November 2023

要約

関数: list llGetClosestNavPoint( vector point, list options );

pointに最も近いナビメッシュ上のポイントを取得するために使用されます。
pointに最も近いナビメッシュ上のポイントを含む単一のベクトル、または空のリスト。を list で返します。

• vector point A point in region-local space
• list options GCNP_* およびその他のフラグとそれに対するパラメータ。optionsテーブルを参照してください。

オプションが明示的に設定されていない場合、そのオプションのデフォルト値が使用されます。

オプション V パラメータ デフォルト 説明
GCNP_RADIUS ] 0 float distance ] 20.0 ] ナビゲーションポイントを検索する範囲を制限します。
GCNP_STATIC ] 1 integer use_static_mesh ] FALSE ] テストが静的または動的なナビメッシュを使用するかどうかを指定します。静的な場合、すべての動的な障害物は無視されます。
CHARACTER_TYPE ] 6 integer type ] CHARACTER_TYPE_NONE ] 指定されたキャラクタータイプのために0%歩行可能でないナビメッシュフェイスを排除して、ナビゲーションポイントをフィルタリングします。デフォルトのCHARACTER_TYPE_NONEの場合、すべてのナビメッシュフェイスが含まれます。

警告

  • 現在の位置から返されたポイントまでの経路が存在することを保証するものではありません。

サンプル

create_character()
{
//  Clear any previous character behaviors
    llDeleteCharacter();

//  default speed is 20
    llCreateCharacter([CHARACTER_DESIRED_SPEED, 10.0]);
    llWanderWithin(llGetPos(), <64.0, 64.0, 2.0>, []);
}

default
{
    on_rez(integer start_param)
    {
        llResetScript();
    }

    state_entry()
    {
        create_character();
    }
 
    touch_start(integer num_detected)
    {
        vector currentPos = llGetPos();
        list points = llGetClosestNavPoint(currentPos, [GCNP_RADIUS, 10.0] );

        if (!llGetListLength(points))
            return;

        llSay(0, "current position " + (string)currentPos
            + " and closest nav point " + (string)llList2Vector(points, 0) );
    }
}

注意点

Using the method incurs a one frame script sleep and the call can be extremely expensive. It is intended to be used in response to a path_update message indicating an inability to reach a requested destination (e.g., because the character or the destination is off the mesh).

特記事項

経緯

Date of Release 31/07/2012

Search JIRA for related Issues

Signature

function list llGetClosestNavPoint( vector point, list options );
この翻訳は 原文 と比べて古いですか?間違いがありますか?読みにくいですか?みんなで 修正 していきましょう! (手順はこちら)
この項目はあなたにとって参考にならない項目ですか?もしかしたらLSL Wikiの関連した項目が参考になるかもしれません。