Version: 2019.1
public CollisionFlags Move (Vector3 motion);

説明

絶対値の移動デルタを受け取り複雑な移動を行います。

motion によってコントローラーを移動させようとするとモーションは衝突判定によって制限されます。 それは、コライダーに沿ってスライドします。 CollisionFlags は移動している間に発生する衝突判定の概要です。 この関数は重力には適用されません。

using UnityEngine;
using System.Collections;

// This script moves the character controller forward // and sideways based on the arrow keys. // It also jumps when pressing space. // Make sure to attach a character controller to the same game object. // It is recommended that you make only one call to Move or SimpleMove per frame.

public class ExampleClass : MonoBehaviour { CharacterController characterController;

public float speed = 6.0f; public float jumpSpeed = 8.0f; public float gravity = 20.0f;

private Vector3 moveDirection = Vector3.zero;

void Start() { characterController = GetComponent<CharacterController>(); }

void Update() { if (characterController.isGrounded) { // We are grounded, so recalculate // move direction directly from axes

moveDirection = new Vector3(Input.GetAxis("Horizontal"), 0.0f, Input.GetAxis("Vertical")); moveDirection *= speed;

if (Input.GetButton("Jump")) { moveDirection.y = jumpSpeed; } }

// Apply gravity. Gravity is multiplied by deltaTime twice (once here, and once below // when the moveDirection is multiplied by deltaTime). This is because gravity should be applied // as an acceleration (ms^-2) moveDirection.y -= gravity * Time.deltaTime;

// Move the controller characterController.Move(moveDirection * Time.deltaTime); } }
Copyright © 2023 Unity Technologies
优美缔软件(上海)有限公司 版权所有
"Unity"、Unity 徽标及其他 Unity 商标是 Unity Technologies 或其附属机构在美国及其他地区的商标或注册商标。其他名称或品牌是其各自所有者的商标。
公安部备案号:
31010902002961