Unity2d轮转图


1.创建一个父物体,生成一个image的预制体

代码如下:

首先计算出圆的周长,半径,弧度

using UnityEngine.EventSystems;
using UnityEngine.UI;
using DG.Tweening;

public class Set2dRotation : MonoBehaviour,IDragHandler,IEndDragHandler
{
    public Image prefeb;
    public int num = 14;
    public float space = 10;
    public float max = 1;
    public float min = 0.5f;
    float l, r, ang;
    public float dec = 10;
    float allang = 0;
    public List<GameObject> list = new List<GameObject>();
    public List<Transform> trans = new List<Transform>();
    // Start is called before the first frame update
    void Start()
    {
        l = num * (prefeb.rectTransform.sizeDelta.x +space);
        r=l/(2*Mathf.PI);
        ang=2*Mathf.PI/num;
        Move();
    }
public void Move()
    {
        for(int i = 0; i < num; i++)
        {
            if(list.Count<=i)
            {
                list.Add(Instantiate(prefeb.gameObject, transform));
                trans.Add(list[i].transform);
            }
            float x = Mathf.Sin(i * ang + allang) * r;
            float z = Mathf.Cos(i * ang + allang) * r;
            float p = (z + r) / (r + r);
            float scale = max * (1 - p) + min * p;
            list[i].transform.localPosition = new Vector3(x, 0, 0);
            list[i].transform.localScale = Vector3.one * scale;
        }
        trans.Sort((a, b) => 
        {
            if (a.localScale.x<b.localScale.x)
            {
                return -1;
            }
            else if(a.localScale.x == b.localScale.x)
            {
                return 0;
            }
            else
            {
                return 1;
            }
        });
        for (int i = 0; i < trans.Count; i++)
        {
            trans[i].SetSiblingIndex(i);
        }
    }

物体添加到集合中,根据物体的大小进行排序

 public void OnDrag(PointerEventData eventData)
    {
        allang -= eventData.delta.x / r;
        Move();
    }

    public void OnEndDrag(PointerEventData eventData)
    {
        float dis = eventData.delta.x;
        float time=Mathf.Abs(dis / dec);
        DOTween.To((a) =>
        {
            allang -= a / r;
            Move();
        }, dis, 0, time).OnComplete(() => 
        {
            float moveang = Mathf.Asin(trans[num - 1].localPosition.x / r);
            float moveanging = Mathf.Abs(moveang * r / dec);
            DOTween.To((b) =>
            {
                allang = b;
                Move();
            },allang,allang+moveang,moveanging);
        });
    }

由于是ui物体,所以直接使用拖拽接口,运用dotween插件实现惯性缓动效果并且实现对齐效果

效果如下:

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值