第一步:创建三个Image(或者多个都行),并且设置Canvas的CanvasScaler脚本组件UI Scale Mode和Reference Resolution的值
data:image/s3,"s3://crabby-images/90f28/90f2853efaa2c93b7f86437667b3321f0242feac" alt=""
第二步:设置三个Image游戏对象的Rect Transform的值
data:image/s3,"s3://crabby-images/53ee6/53ee6cc89fe9760d0200055d020d69aa620cad02" alt=""
第三步:新建一个空物体GameObject重命名为Images
data:image/s3,"s3://crabby-images/41deb/41debf31de675b84774a7504d49e5c758f907fde" alt=""
data:image/s3,"s3://crabby-images/f7b06/f7b06d860f64674b73752e3a593032b9d72ace70" alt=""
第四步:新建Scripts空物体(用来挂载脚本)和SliderPage脚本,并且将脚本挂载上去
data:image/s3,"s3://crabby-images/f03e3/f03e317096eb4d62f08b8da7b0a1d0e71b2993f5" alt=""
第五步:下载并且导入DoTween插件
data:image/s3,"s3://crabby-images/995f9/995f9bc43e7d524252dac4474c4273684ce34c2b" alt=""
data:image/s3,"s3://crabby-images/ab9bc/ab9bcca7ed4d69e882549b8e3d4cdf7a0eb4532e" alt=""
第六步:编辑SliderPage脚本
data:image/s3,"s3://crabby-images/b26a8/b26a825313e5a35619424256dd9eae122c51c691" alt=""
data:image/s3,"s3://crabby-images/89228/89228a9e4aec95422b4d543449a711ea41f1ebe2" alt=""
data:image/s3,"s3://crabby-images/e9653/e96539bf663bd4f7802be1843f09a7e03c2a9512" alt=""
附 SliderPage.cs代码:
using System.Collections;
using System.Collections.Generic;
using UnityEngine;
using UnityEngine.UI;
using DG.Tweening;
public class SliderPage : MonoBehaviour {
[Tooltip("Images页面集合")]
public Transform m_images;
// Use this for initialization
void Start () {
//初始化Image页面 排列位置
for (int idx = 0; idx < m_images.childCount; idx++)
{
//初始化m_images的父物体位置
if (idx.Equals(0))
{
m_images.GetComponent<RectTransform>().anchoredPosition = Vector2.zero;
//设置第一个image的位置
m_images.GetChild(idx).GetComponent<RectTransform>().anchoredPosition = Vector2.zero;
}
else
{
//排列每个Images的位置(除了第一个image外)
float PreWidth = .5f * (m_images.GetChild(idx-1).GetComponent<RectTransform>().rect.width + m_images.GetChild(idx).GetComponent<RectTransform>().rect.width);
m_images.GetChild(idx).GetComponent<RectTransform>().anchoredPosition = new Vector2(idx * PreWidth, 0);
}
//随机设置image的颜色
Color color = new Color((Random.Range(0, 256) / 255f), (Random.Range(0, 256) / 255f), (Random.Range(0, 256) / 255f));
m_images.GetChild(idx).GetComponent<Image>().color = color;
}
}
// Update is called once per frame
void Update () {
OnSliderPage();
}
bool isDown = false;
float mousePosX;
float runtimePos;
float deltaX;
int sliderIndex = 0;
void OnSliderPage()
{
if (Input.GetMouseButtonDown(0))
{
isDown = true;
mousePosX = Input.mousePosition.x;
runtimePos = m_images.GetComponent<RectTransform>().anchoredPosition.x;
}
if (Input.GetMouseButtonUp(0))
{
isDown = false;
float width = m_images.GetChild(0).GetComponent<RectTransform>().rect.width;
if (Mathf.Abs(deltaX) >= (width / 2) || Mathf.Abs(Input.GetAxis("Mouse X")) >= 3)
{
if (deltaX > 0)
{
//向右
sliderIndex++;
if (sliderIndex > 0)
sliderIndex = 0;
}
else
{
//向左
sliderIndex--;
if (sliderIndex < (-m_images.childCount+1))
sliderIndex = -m_images.childCount + 1;
}
m_images.GetComponent<RectTransform>().DOAnchorPosX(sliderIndex * width, 0.5f);
}
else
{
m_images.GetComponent<RectTransform>().DOAnchorPosX(sliderIndex * width, 0.5f);
//恢复
}
}
if (isDown)
{
deltaX = Input.mousePosition.x - mousePosX;
m_images.GetComponent<RectTransform>().anchoredPosition = new Vector2(deltaX + runtimePos, 0);
}
}
}
运行效果:
data:image/s3,"s3://crabby-images/aadbe/aadbef0cbc9c06544124a38d396c1b11e2147478" alt=""
项目源码:github
网友评论