Unity使用ScrollRect制作翻頁
本文實(shí)例為大家分享了使用ScrollRect制作翻頁的具體代碼,供大家參考,具體內(nèi)容如下
1.標(biāo)準(zhǔn)的層級(jí)結(jié)構(gòu) ScrollRect->ViewPort->Content,Viewport負(fù)責(zé)顯示區(qū)域的大小一般和Mask一起配合使用,Content使用Layout來布局,如果想使用代碼來自動(dòng)定位顯示位置需要在Content加上Content size filter.
2.ScrollRectHelper
using UnityEngine; using UnityEngine.UI; using UnityEngine.EventSystems; using System.Collections.Generic; using System; public class ScrollRectHelper : MonoBehaviour, IBeginDragHandler, IEndDragHandler { // 滑動(dòng)速度 public float smooting = 5; // 每頁顯示的項(xiàng)目 [SerializeField] private int countPerPage = 10; ScrollRect srect; // 總頁數(shù) float totalPages; // 是否拖拽結(jié)束 bool isDrag = false; // 總頁數(shù)索引比列 0-1 List<float> listPageValue = new List<float> { 0 }; // 滑動(dòng)的目標(biāo)位置 public float targetPos = 0; // 當(dāng)前位置索引 float nowindex = 0; void Awake() { srect = GetComponent<ScrollRect>(); } public string PageText() { return (nowindex + 1) + "/" + (totalPages + 1); } // 計(jì)算每頁比例 public void CalcListPageValue<T>() where T : MonoBehaviour { T[] items = srect.content.GetComponentsInChildren<T>(); srect.content.rect.Set(srect.content.rect.width / 2, srect.content.rect.y, srect.content.rect.width, srect.content.rect.height); totalPages = (int)(Math.Ceiling((float)items.Length / countPerPage) - 1); if (items.Length != 0) { for (float i = 1; i <= totalPages; i++) { //Debug.Log(i / totalPages); listPageValue.Add((i / totalPages)); } } } void Update() { if (!isDrag) { srect.horizontalNormalizedPosition = Mathf.Lerp(srect.horizontalNormalizedPosition, targetPos, Time.deltaTime * smooting); } // Debug if (Input.GetKeyDown(KeyCode.LeftArrow)) PressLeft(); if (Input.GetKeyDown(KeyCode.RightArrow)) PressRight(); } /// <summary> /// 拖動(dòng)開始 /// </summary> /// <param name="eventData"></param> public void OnBeginDrag(PointerEventData eventData) { isDrag = true; } /// <summary> /// 拖拽結(jié)束 /// </summary> /// <param name="eventData"></param> public void OnEndDrag(PointerEventData eventData) { isDrag = false; var tempPos = srect.horizontalNormalizedPosition; //獲取拖動(dòng)的值 var index = 0; float offset = Mathf.Abs(listPageValue[index] - tempPos); //拖動(dòng)的絕對(duì)值 for (int i = 1; i < listPageValue.Count; i++) { float temp = Mathf.Abs(tempPos - listPageValue[i]); if (temp < offset) { index = i; offset = temp; } } targetPos = listPageValue[index]; nowindex = index; } public void PressLeft() { nowindex = Mathf.Clamp(nowindex - 1, 0, totalPages); targetPos = listPageValue[Convert.ToInt32(nowindex)]; } public void PressRight() { nowindex = Mathf.Clamp(nowindex + 1, 0, totalPages); targetPos = listPageValue[Convert.ToInt32(nowindex)]; } }
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
C#使用三層架構(gòu)開發(fā)Winform的詳細(xì)案例
這篇文章介紹了C#使用三層架構(gòu)開發(fā)Winform的詳細(xì)案例,文中通過示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-04-04C#實(shí)現(xiàn)簡(jiǎn)易點(diǎn)餐功能
這篇文章主要為大家詳細(xì)介紹了C#實(shí)現(xiàn)簡(jiǎn)易點(diǎn)餐功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-07-07C#設(shè)計(jì)模式之Strategy策略模式解決007大破密碼危機(jī)問題示例
這篇文章主要介紹了C#設(shè)計(jì)模式之Strategy策略模式解決007大破密碼危機(jī)問題,簡(jiǎn)單描述了策略模式的定義并結(jié)合加密解密算法實(shí)例分析了C#策略模式的具體使用方法,需要的朋友可以參考下2017-09-09