Unity工具類ScrollView實(shí)現(xiàn)拖拽滑動(dòng)翻頁(yè)
簡(jiǎn)介:
在進(jìn)行UI設(shè)計(jì)的時(shí)候,經(jīng)常會(huì)使用Unity中UI提供的ScrollView,類似Android中的ScrollView,在進(jìn)行圖片預(yù)覽,多個(gè)翻頁(yè)的時(shí)候,能實(shí)現(xiàn)很好的效果。
該類中根據(jù)Unity的EventSystems中拖拽事件,實(shí)現(xiàn)對(duì)頁(yè)碼的滑動(dòng)監(jiān)聽(tīng),在使用的時(shí)候,新建UI--->ScrollView,把該類組件添加到ScrollView上,把對(duì)應(yīng)的content加入該腳本中的content,調(diào)整ScrollView和Content,設(shè)置單個(gè)滑動(dòng)頁(yè)的寬度,拖拽的閾值,即可監(jiān)聽(tīng)到拖拽,如果是動(dòng)態(tài)實(shí)例化ScrollView中的child,需設(shè)置當(dāng)前最大頁(yè)碼數(shù)。SetCurIndex可以實(shí)現(xiàn)直接定位到當(dāng)前頁(yè)碼對(duì)應(yīng)的滑動(dòng)頁(yè),代碼比較簡(jiǎn)單,直接貼出來(lái)。
public class ScrollViewListener : MonoBehaviour, IDragHandler, IBeginDragHandler, IEndDragHandler
{
//滑動(dòng)方向
public enum MoveDirection
{
None = 0,
Left,
Right,
}
public float SingleItemWidth;//單個(gè)滑動(dòng)頁(yè)的寬度
public RectTransform content;//當(dāng)前ScrollView的Content
public float DragMinValue = 5f;//拖動(dòng)過(guò)程中允許的最小的拖拽值,低于此值就不算拖拽,不執(zhí)行翻頁(yè)事件
private MoveDirection direction = MoveDirection.None;
private int CurIndex = 0;//當(dāng)前頁(yè)碼
private int MaxIndex = 0;//最大頁(yè)碼
public bool canMove = true;//是否能移動(dòng)
private Vector3 originalPos;
private float maxDeltaX = 0f;//取整個(gè)拖動(dòng)過(guò)程中的最大值
public Action<int> OnPageChange;//對(duì)外提供頁(yè)碼修改的回調(diào)
/// <summary>
/// 滑到下一頁(yè)
/// </summary>
private void MoveToNext()
{
if (direction == MoveDirection.Left)
{
if (CurIndex < MaxIndex)
{
CurIndex++;
canMove = false;
content.DOLocalMoveX(content.localPosition.x - SingleItemWidth, 1f).OnComplete(() =>
{
if (null != OnPageChange)
{
OnPageChange(CurIndex);
}
canMove = true;
});
}
}
else if (direction == MoveDirection.Right)
{
if (CurIndex > 0)
{
CurIndex--;
canMove = false;
content.DOLocalMoveX(content.localPosition.x + SingleItemWidth, 1f).OnComplete(() =>
{
if (null != OnPageChange)
{
OnPageChange(CurIndex);
}
canMove = true;
});
}
}
}
/// <summary>
/// 設(shè)置當(dāng)前滑動(dòng)列表的頁(yè)數(shù)的最大值
/// </summary>
/// <param name="max"></param>
public void SetMaxIndex(int max)
{
MaxIndex = max - 1;//最大下標(biāo)值為頁(yè)數(shù)減1
}
/// <summary>
/// 設(shè)置當(dāng)前頁(yè)
/// </summary>
/// <param name="index"></param>
public void SetCurIndex(int index)
{
CurIndex = index;
float x = content.localPosition.x - SingleItemWidth * CurIndex;
content.localPosition = new Vector3(x, content.localPosition.y, content.localPosition.z);
}
public void ResetPosition()
{
content.localPosition = originalPos;
}
private void Awake()
{
CurIndex = 0;
originalPos = content.localPosition;
}
public void OnDrag(PointerEventData eventData)
{
if (Mathf.Abs(eventData.delta.x) > maxDeltaX)
{
maxDeltaX = Mathf.Abs(eventData.delta.x);
}
}
public void OnBeginDrag(PointerEventData eventData)
{
if (eventData.delta.x > 0)
{
direction = MoveDirection.Right;
}
else if (eventData.delta.x < 0)
{
direction = MoveDirection.Left;
}
else
{
direction = MoveDirection.None;
}
if (Mathf.Abs(eventData.delta.x) > maxDeltaX)
{
maxDeltaX = Mathf.Abs(eventData.delta.x);
}
}
public void OnEndDrag(PointerEventData eventData)
{
if (Mathf.Abs(eventData.delta.x) > maxDeltaX)
{
maxDeltaX = Mathf.Abs(eventData.delta.x);
}
if (maxDeltaX > DragMinValue)
{
//計(jì)算下一頁(yè)的目的點(diǎn) 然后移動(dòng)
if (canMove)
{
MoveToNext();
}
}
maxDeltaX = 0f;
}
}
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
c#菜單動(dòng)態(tài)合并的實(shí)現(xiàn)方法
這篇文章主要介紹了c#菜單動(dòng)態(tài)合并的實(shí)現(xiàn)方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-10-10
C#使用TimeSpan對(duì)象實(shí)現(xiàn)獲取時(shí)間間隔
TimeSpan對(duì)象代表兩個(gè)時(shí)間段的間隔或跨度,使用TimeSpan對(duì)象可以方便地獲取兩個(gè)時(shí)間段的間隔,下面我們就來(lái)看看C#使用TimeSpan對(duì)象實(shí)現(xiàn)獲取時(shí)間間隔的具體操作吧2024-01-01
ftp服務(wù)器搭建部署與C#實(shí)現(xiàn)ftp文件的上傳的示例
本文主要介紹了ftp服務(wù)器搭建部署與C#實(shí)現(xiàn)ftp文件的上傳的示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-07-07
C#根據(jù)年月日計(jì)算星期幾的函數(shù)小例子
這篇文章介紹了C#根據(jù)年月日計(jì)算星期幾的函數(shù)小例子,有需要的朋友可以參考一下2013-07-07
C#連接數(shù)據(jù)庫(kù)和更新數(shù)據(jù)庫(kù)的方法
這篇文章主要介紹了C#連接數(shù)據(jù)庫(kù)和更新數(shù)據(jù)庫(kù)的方法,需要的朋友可以參考下2015-08-08

