お好みのスクリプト言語を選択すると、サンプルコードがその言語で表示されます。
Thank you for helping us improve the quality of Unity Documentation. Although we cannot accept all submissions, we do read each suggested change from our users and will make updates where applicable.
Close直線上にある2つのベクトル間を補間します
from
で from
と to
の間を補間します。これは最も一般的な
2点を終点としたライン上のある部分を見つけるために使用します。
(例えば、オブジェクトを2点の間で徐々に移動させる)
数は[0...1]の範囲に制限されます。
from
= 0 の時は from
を返します。
to
= 1 の時は to
を返します。
from
= 0.5 の時は from
と to
の平均(ちょうど真ん中)を返します。
// Transforms to act as start and end markers for the journey. var startMarker: Transform; var endMarker: Transform; // Movement speed in units/sec. var speed = 1.0; // Time when the movement started. private var startTime: float; // Total distance between the markers. private var journeyLength: float; var target : Transform; var smooth = 5.0; function Start() { // Keep a note of the time the movement started. startTime = Time.time; // Calculate the journey length. journeyLength = Vector3.Distance(startMarker.position, endMarker.position); } // Follows the target position like with a spring function Update () { // Distance moved = time * speed. var distCovered = (Time.time - startTime) * speed; // Fraction of journey completed = current distance divided by total distance. var fracJourney = distCovered / journeyLength; // Set our position as a fraction of the distance between the markers. transform.position = Vector3.Lerp(startMarker.position, endMarker.position, fracJourney); }
using UnityEngine; using System.Collections; public class ExampleClass : MonoBehaviour { public Transform startMarker; public Transform endMarker; public float speed = 1.0F; private float startTime; private float journeyLength; public Transform target; public float smooth = 5.0F; void Start() { startTime = Time.time; journeyLength = Vector3.Distance(startMarker.position, endMarker.position); } void Update() { float distCovered = (Time.time - startTime) * speed; float fracJourney = distCovered / journeyLength; transform.position = Vector3.Lerp(startMarker.position, endMarker.position, fracJourney); } }
import UnityEngine import System.Collections public class ExampleClass(MonoBehaviour): public startMarker as Transform public endMarker as Transform public speed as float = 1.0F private startTime as float private journeyLength as float public target as Transform public smooth as float = 5.0F def Start() as void: startTime = Time.time journeyLength = Vector3.Distance(startMarker.position, endMarker.position) def Update() as void: distCovered as float = ((Time.time - startTime) * speed) fracJourney as float = (distCovered / journeyLength) transform.position = Vector3.Lerp(startMarker.position, endMarker.position, fracJourney)