unity UGUI無限滾動(dòng)

在開始時(shí)悼凑,我們需要理解在UI中RectTransform中的Pivot筷屡。
Pivot相當(dāng)與一張圖片的中心點(diǎn)
例如:


image.png

圖片位置的軸是以Pivot作為軸的中心,來計(jì)算當(dāng)前圖片的位置信息。


image.png

了解pivot的軸心的位置便于我們?cè)O(shè)置滑動(dòng)UI的邊界
pivot(0,0)


image.png

pivot(1,0)


image.png

pivot(1,1)
image.png

pivot(0,1)
image.png

這里以左右無限滑動(dòng)作為例子
在明白pivot的作用后雇逞,我們需要設(shè)置左邊、右邊的邊界(邊界:當(dāng)圖片到達(dá)邊界時(shí)自動(dòng)移動(dòng)位置)

邊界

image.png

首頁(yè)需要把這些對(duì)象的pivot設(shè)置為(0,0)
左邊界:
LimitLeft=scrollRect.transform.TransformPoint(Vector3.zero).x;
獲取左邊的滾動(dòng)矩形的最左邊的位置
往左邊滑動(dòng)
方法一: cueerntImageLeft=獲取最左邊的圖片的錨點(diǎn)的X軸+圖片與圖片的間距
方法二:Vector3 X=new Vector3 (獲取最左邊的圖片的局部坐標(biāo)+ImgeSize,0,0);
cueerntImageLeft=ScrollRect.transform.TransformPoint(X).x;
if(LimitLeft=>cueerntImageLeft)
{
圖片排序一次茁裙,
把最左邊的圖片替換把右邊
}

右邊界:
Vector3 scrollRectAnchorRight = new Vector3 (獲取scrollRect的寬度+圖片與圖片的間距)塘砸;
LimitRight=scrollRect.transform.TransformPoint(scrollRectAnchorRight )
.x;
往右邊滑動(dòng):
根據(jù)左邊的一樣同理,只不過這次獲取的是最右邊的圖片
if(LimitRight<=cueerntImageRight)
{
圖片排序一次晤锥,
把最右邊的圖片替換把左邊
}

這里需要了解 父級(jí).transform.TransformPoint:
在官方的解釋中:局部左邊轉(zhuǎn)換為世界坐標(biāo)

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

public class Test : MonoBehaviour
{
    public RectTransform content;   //滑動(dòng)內(nèi)容
    public ScrollRect scrollRect;

    private ContentSizeFitter contentSizeFitter;
    private HorizontalLayoutGroup horizontalLayoutGroup;

    private List<RectTransform> ShowImageList = new List<RectTransform>();     //存儲(chǔ)循環(huán)顯示的Image
    private RectTransform scrollRectTransform;

    private float Startpoitios;     //記錄開始的位置     
    private float curretPosition;   //當(dāng)前的位置信息
    private float scrollRectLeft;   //滑動(dòng)的參照點(diǎn)
    private float ImgeSize = 300;   //圖片的大小
    public int indeximage;         //UI的ID

    [HideInInspector] private int count = 20;  //顯示顯示的個(gè)數(shù)

    private void Awake()
    {
        InitCompent();
    }

    void Start()
    {
        InitContentList();
        Invoke("EnablEdcompent", .1f);
    }

    //克隆
    public void InitContentList()
    {
        foreach (RectTransform rectTransform in content)
        {
            indeximage++;
            ShowImageList.Add(rectTransform);
        }
    }

    public void InitCompent()
    {
        contentSizeFitter = content.GetComponent<ContentSizeFitter>();
        horizontalLayoutGroup = content.GetComponent<HorizontalLayoutGroup>();
        scrollRect = scrollRect.GetComponent<ScrollRect>();
        //左邊的邊界
         scrollRectLeft = scrollRect.transform.TransformPoint(Vector3.zero).x;
        //  scrollRectLeft = scrollRectTransform.anchoredPosition.x;
        scrollRectTransform = scrollRect.GetComponent<RectTransform>();
     
        scrollRect.onValueChanged.AddListener((data) => { infiniteScroll(data); });
    }

    public void EnablEdcompent()
    {
        horizontalLayoutGroup.enabled = false;
        contentSizeFitter.enabled = false;
    }

    //無限滑動(dòng)
    public void infiniteScroll(Vector2 data)
    {
        //  float Left = content.transform.TransformPoint(ShowImageList[0].localPosition.x + ImgeSize, ShowImageList[0].localPosition.y, 0).x;
        float Left = ShowImageList[0].position.x + ImgeSize;
        curretPosition = content.GetComponent<RectTransform>().anchoredPosition.x;
        float offsetX = curretPosition - Startpoitios;

        if (offsetX < 0)
        {
            if (indeximage + 1 <= count)
            {
                Startpoitios = curretPosition;
                Debug.LogError("A:"+ (Left + ImgeSize)+"B:"+ scrollRectLeft);
                if (Left + ImgeSize <= scrollRectLeft)
                {
                    ShowImageList[0].transform.SetAsLastSibling();
                    ShowImageList[0].anchoredPosition =
                    new Vector3(ShowImageList[ShowImageList.Count - 1].anchoredPosition.x + horizontalLayoutGroup.spacing + ImgeSize, ShowImageList[0].anchoredPosition.y, 0);
                    indeximage++;
                    for (int i = 0; i < ShowImageList.Count; i++)
                    {
                        ShowImageList[i] = content.transform.GetChild(i).GetComponent<RectTransform>();
                    }
                    content.GetComponent<RectTransform>().sizeDelta += new Vector2(horizontalLayoutGroup.spacing + ImgeSize, 0);
                }
            }
        }
        else
        {
            //   Vector3 scrollRectAnchorRight = new Vector3(scrollRectTransform.rect.width + horizontalLayoutGroup.spacing, 0, 0f);
            //float scrollRectRight = scrollRect.transform.TransformPoint(scrollRectAnchorRight).x;
             float scrollRectRight = scrollRectLeft + scrollRectTransform.rect.width + horizontalLayoutGroup.spacing;
            Vector3 childUpRight = new Vector3(ShowImageList[ShowImageList.Count - 1].anchoredPosition.x, ShowImageList[ShowImageList.Count - 1].anchoredPosition.y, 0f);
            float childRight = content.transform.TransformPoint(childUpRight).x;
            if (childRight >= scrollRectRight + ImgeSize)
            {
                if (indeximage - ShowImageList.Count == 0)
                {
                    return;
                }
                ShowImageList[ShowImageList.Count - 1].SetAsFirstSibling();
                indeximage--;
                ShowImageList[ShowImageList.Count - 1].anchoredPosition = new Vector2(ShowImageList[0].anchoredPosition.x - horizontalLayoutGroup.spacing - ImgeSize, ShowImageList[ShowImageList.Count - 1].anchoredPosition.y);
                for (int i = 0; i < ShowImageList.Count; i++)
                {
                    ShowImageList[i] = content.transform.GetChild(i).GetComponent<RectTransform>();
                }
                content.GetComponent<RectTransform>().sizeDelta -= new Vector2(horizontalLayoutGroup.spacing + ImgeSize, 0);
            }
        }
        Startpoitios = curretPosition;
    }

    private void OnDisable()
    {
        indeximage = 0;
        if(horizontalLayoutGroup!=null)
        horizontalLayoutGroup.enabled = true;
        if(contentSizeFitter!=null)
        contentSizeFitter.enabled = true;
    }
}

Image.gif
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末掉蔬,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子矾瘾,更是在濱河造成了極大的恐慌女轿,老刑警劉巖,帶你破解...
    沈念sama閱讀 217,657評(píng)論 6 505
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件壕翩,死亡現(xiàn)場(chǎng)離奇詭異蛉迹,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)放妈,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,889評(píng)論 3 394
  • 文/潘曉璐 我一進(jìn)店門北救,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人芜抒,你說我怎么就攤上這事珍策。” “怎么了宅倒?”我有些...
    開封第一講書人閱讀 164,057評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵攘宙,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我,道長(zhǎng)模聋,這世上最難降的妖魔是什么肩民? 我笑而不...
    開封第一講書人閱讀 58,509評(píng)論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮链方,結(jié)果婚禮上持痰,老公的妹妹穿的比我還像新娘。我一直安慰自己祟蚀,他們只是感情好工窍,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,562評(píng)論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著前酿,像睡著了一般患雏。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上罢维,一...
    開封第一講書人閱讀 51,443評(píng)論 1 302
  • 那天淹仑,我揣著相機(jī)與錄音,去河邊找鬼肺孵。 笑死匀借,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的平窘。 我是一名探鬼主播吓肋,決...
    沈念sama閱讀 40,251評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼瑰艘!你這毒婦竟也來了是鬼?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,129評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤紫新,失蹤者是張志新(化名)和其女友劉穎均蜜,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體芒率,經(jīng)...
    沈念sama閱讀 45,561評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡兆龙,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,779評(píng)論 3 335
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了敲董。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,902評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡慰安,死狀恐怖腋寨,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情化焕,我是刑警寧澤萄窜,帶...
    沈念sama閱讀 35,621評(píng)論 5 345
  • 正文 年R本政府宣布,位于F島的核電站,受9級(jí)特大地震影響查刻,放射性物質(zhì)發(fā)生泄漏键兜。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,220評(píng)論 3 328
  • 文/蒙蒙 一穗泵、第九天 我趴在偏房一處隱蔽的房頂上張望普气。 院中可真熱鬧,春花似錦佃延、人聲如沸现诀。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,838評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)仔沿。三九已至,卻和暖如春尺棋,著一層夾襖步出監(jiān)牢的瞬間封锉,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,971評(píng)論 1 269
  • 我被黑心中介騙來泰國(guó)打工膘螟, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留成福,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,025評(píng)論 2 370
  • 正文 我出身青樓萍鲸,卻偏偏與公主長(zhǎng)得像闷叉,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子脊阴,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,843評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容

  • 前言 最近一段時(shí)間的實(shí)習(xí)都是苦逼的在做ui握侧,做移動(dòng)端的,適配是永恒的話題嘿期,慶幸的是unity提供了一套強(qiáng)大的接口讓...
    巨龍餓了閱讀 66,102評(píng)論 20 139
  • Unity腳本基礎(chǔ) 1.Unity3D中的協(xié)程(coroutine)和C#線程之間的區(qū)別是什么品擎? 多線程程序同時(shí)運(yùn)...
    豆錚閱讀 3,602評(píng)論 0 3
  • 1、UGUI概述 1.1备徐、Unity界面發(fā)展史 【老版本界面onGUI】=>【GUI插件NGUI】=>【新版本界面...
    兜兜_2925閱讀 27,406評(píng)論 2 23
  • 這是今天的成果吧,雖然還是沒有全部完成,但是大致的功能已經(jīng)實(shí)現(xiàn),飛機(jī)的移動(dòng),限制移動(dòng)范圍,子彈的發(fā)射,消滅敵人萄传,敵...
    Unity學(xué)習(xí)的路上閱讀 2,839評(píng)論 1 2
  • 盡可能的讓UI元素合批 首先創(chuàng)建一個(gè)新的場(chǎng)景,攝像camera為Solod Color 然后創(chuàng)建兩個(gè)Button ...
    qiaoqiao123閱讀 1,519評(píng)論 0 1