如何實現(xiàn)UnityUI拖拽模型選擇功能-創(chuàng)新互聯(lián)

這篇文章給大家分享的是有關(guān)如何實現(xiàn)Unity UI拖拽模型選擇功能的內(nèi)容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。

成都創(chuàng)新互聯(lián)公司-專業(yè)網(wǎng)站定制、快速模板網(wǎng)站建設(shè)、高性價比環(huán)縣網(wǎng)站開發(fā)、企業(yè)建站全套包干低至880元,成熟完善的模板庫,直接使用。一站式環(huán)縣網(wǎng)站制作公司更省心,省錢,快速模板網(wǎng)站建設(shè)找我們,業(yè)務(wù)覆蓋環(huán)縣地區(qū)。費用合理售后完善,十載實體公司更值得信賴。

指定一塊區(qū)域,玩家鼠標or手指拖拽這個區(qū)域,模型會進行偏移,并用于進行人物、道具的選擇

給模型定義一些屬性

using System.Collections;
using System.Collections.Generic;
using UnityEngine;

public class UIModelUtil : MonoBehaviour
{
  public Animator animator;
  public int id;
  public int index;

}

模型控制

using System.Collections;
using System.Collections.Generic;
using UnityEngine;

public class UIModelControl : MonoBehaviour
{
  public Transform modelsParent;
  public Transform centerPos;
  public float interval;
  public bool loop;

  List<UIModelUtil> models;
  bool isPressing;
  public UIDrag dragComp;


  Vector3 mousePos;

  private void Awake()
  {
    if(models == null)
    {
      int i = 0;
      models = new List<UIModelUtil>();
      foreach(UIModelUtil util in modelsParent.GetComponentsInChildren<UIModelUtil>())
      {
        models.Add(util);
        //util.index = i;
        Vector3 pos = Vector3.zero;
        pos.x = i * interval;
        util.transform.localPosition = pos;
        i++;
      }
    }
  }

  private void Start()
  {
    JumpToSelect();
  }

  
  private void Update()
  {
    //接受拖拽事件
    if (isPressing)
    {
      float x = GetInputDeltaX();
      int dir = 0;
      if (x > 0) dir = 1;
      else if (x < 0) dir = -1;

      //分辨率修正
      if (dir == 0) return;
      x = Mathf.Abs(x) / (Screen.width) * 800f;
      if (x > 800f) x = 800f;

      //偏移
      float currectX = Mathf.Lerp(0, interval, x / 800f) * dir;
      Vector3 pos = modelsParent.position;
      pos.x += currectX;



        Transform right = GetRight().transform;
        Transform left = GetLeft().transform;
      //不循環(huán)時候設(shè)置邊框
      if (models.Count > 2 || !loop || models.Count == 1)
      {
    

        if (right.localPosition.x + interval / 10 < -pos.x) pos.x = -(right.localPosition.x + interval / 10);
        else if (left.localPosition.x - interval / 10 > -pos.x) pos.x = -(left.localPosition.x - interval / 10);

        //modelsParent.position = pos;
      }
      //只有兩個循環(huán)的時候
      else if (models.Count == 2 && loop)
      {

        Transform selected = GetSelect().transform;
        //當(dāng)前是右邊那個且向右拖拽
        if (selected == right && dir < 0)
        {
          
          Vector3 leftPos = left.localPosition;
          leftPos.x = right.localPosition.x + interval;
          left.localPosition = leftPos;
        }
        //當(dāng)前是左邊那個且向左拖拽
        else if (selected == left && dir > 0)
        {
          Vector3 rightPos = right.localPosition;
          rightPos.x = left.localPosition.x - interval;
          right.localPosition = rightPos;
        }
      }
      modelsParent.position = pos;
      
      AfterSelect();
    }
  }


  void AfterSelect()
  {
    foreach(UIModelUtil util in models)
    {
      float dis = GetXDis(util);
      //設(shè)置顯示
      if (dis > interval)
        util.gameObject.SetActive(false);
      else
      { 
        //越靠近中間越前
        util.gameObject.SetActive(true);
        float t = Mathf.Abs(dis) / interval;
        float y = Mathf.Lerp(centerPos.position.z, modelsParent.position.z, t);
        Vector3 pos = util.transform.position;
        pos.z = y;
        util.transform.position = pos;
      }

    }
    //循環(huán)時候位置修正
    if (loop && models.Count > 2)
    {
      Transform right = GetRight().transform;
      Transform left = GetLeft().transform;
      Transform selected = GetSelect().transform;
      if (selected == right)
      {
        Vector3 pos = right.position;
        pos.x += interval;
        left.position = pos;
      }
      else if (selected == left)
      {
        Vector3 pos = left.position;
        pos.x -= interval;
        right.position = pos;
      }
    }
    //設(shè)置UI選中狀況
    dragComp.OnSelected(GetSelect().id, GetSelect().index);
  }

  //通過id選中
   UIModelUtil GetById(int id)
  {
    if (models == null) return null;
    UIModelUtil target = null;

    foreach (UIModelUtil util in models)
    {
      if (util.id == id) return util;
    }
    return target;
  }

  //獲取當(dāng)前選中
   UIModelUtil GetSelect()
  {
    if (models == null) return null;
    float min = 9999;

    UIModelUtil target = null;

    foreach(UIModelUtil util in models)
    {
      float dis = Mathf.Abs( GetXDis(util));
      if(dis < min)
      {
        target = util;
        min = dis;
      }
    }
    return target;
  }

  //所有模型最右邊的那個
   UIModelUtil GetRight()
  {
    if (models == null) return null;
    float max = -9999;

    UIModelUtil target = null;

    foreach(UIModelUtil util in models)
    {
      float dis = util.transform.localPosition.x;
      if(dis > max)
      {
        target = util;
        max = dis;
      }
    }

    return target;
  }

  //所有模型最左邊的那個
   UIModelUtil GetLeft()
  {
    if (models == null) return null;
    float min = 9999;

    UIModelUtil target = null;

    foreach(UIModelUtil util in models)
    {
      float dis = util.transform.localPosition.x;
      if(dis < min)
      {
        target = util;
        min = dis;
      }
    }


    return target;
  }

  //UI控件按下觸發(fā)
  public void OnPress()
  {
    if (isPressing) return;
    isPressing = true;

    if (Application.isEditor)
      mousePos = Input.mousePosition;
    else
      mousePos = Input.GetTouch(0).position;
    if (backing != null) StopCoroutine(backing);
  }

  //UI控件釋放觸發(fā)
  public void OnRelease()
  {
    backing = StartCoroutine(ToSelect());
    isPressing = false;
  }


  Coroutine backing;
  //釋放后偏移
  IEnumerator ToSelect()
  {


    UIModelUtil selected = GetSelect();
    float dis = GetXDis(selected);
    float time = Mathf.Lerp (0, 1f, Mathf.Abs(dis) / interval);
    float timer = 0;
    Vector3 from = modelsParent.localPosition;
    Vector3 to = from;
    to.x = -selected.transform.localPosition.x;

    while(timer < time)
    {
      timer += Time.deltaTime;
      float t = timer / time;
      Vector3 pos = Vector3.Lerp(from, to, t);
      modelsParent.localPosition = pos;
      AfterSelect();
      yield return null;
    }
    backing = null;

  }

  //獲取手指偏移量
  float GetInputDeltaX()
  {
    Vector3 pos;
    if (Application.isEditor)
      pos = Input.mousePosition;
    else
      pos = Input.GetTouch(0).position;
    Vector3 delta = pos - mousePos;
    //Debug.Log(pos +"/"+mousePos +"/"+ delta.x);
    mousePos = pos;
    return delta.x;
      
  }

  //計算偏移中心位置的X軸距離
  float GetXDis(UIModelUtil util)
  {
    return util.transform.position.x - centerPos.position.x;
  }

  // 跳轉(zhuǎn)到選中的id
  public void JumpToSelect()
  {
    int id = CharacterManager.characterId;
    Vector3 pos = modelsParent.localPosition;
    UIModelUtil selected = GetById(id);
    pos.x = -selected.transform.localPosition.x;
    modelsParent.localPosition = pos;

    AfterSelect();
  }


}

UI接受點擊事件:

using System.Collections;
using System.Collections.Generic;
using UnityEngine;
using UnityEngine.EventSystems;
public class UIDrag : MonoBehaviour,IPointerDownHandler, IPointerUpHandler
{
  public UIModelControl control;

  virtual public void OnPointerDown(PointerEventData data)
  {
    control.OnPress();
  }

  virtual public void OnPointerUp(PointerEventData data)
  {
    control.OnRelease();
  }

  virtual public void OnSelected(int id, int index)
  {

  }
}

感謝各位的閱讀!關(guān)于“如何實現(xiàn)Unity UI拖拽模型選擇功能”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,讓大家可以學(xué)到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機、免備案服務(wù)器”等云主機租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。

標題名稱:如何實現(xiàn)UnityUI拖拽模型選擇功能-創(chuàng)新互聯(lián)
當(dāng)前網(wǎng)址:http://www.muchs.cn/article26/pcijg.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站制作網(wǎng)站收錄、網(wǎng)站維護、靜態(tài)網(wǎng)站、企業(yè)網(wǎng)站制作、網(wǎng)站導(dǎo)航

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

網(wǎng)站托管運營