Unity3D實(shí)現(xiàn)導(dǎo)航效果
介紹:
unity界面開發(fā),會(huì)用到很多導(dǎo)航的按鈕,他們是公共的,單擊其中一個(gè)按鈕,顯示對(duì)應(yīng)的界面。
unity中,UGUI自帶Toggle組件,NGUI也有Toggle復(fù)選框,都方便了開發(fā)者的開發(fā)。但是只有合適自己才是王道。
今天,就用普通的按鈕組建,來編寫自己的導(dǎo)航。
導(dǎo)航的組成:
- 總控制
- 按鈕組
- 面板組
步驟:
編寫腳本:<NavigationButton> 控制按鈕的高亮,動(dòng)畫等。
編寫腳本:<NavigationPanel> 控制面板的顯示和關(guān)閉。
編寫腳本:<NavigationGroup> 控制整個(gè)導(dǎo)航按鈕的邏輯。
編寫腳本: <MainManager> 控制導(dǎo)航欄的邏輯。
NavigationButton:
控制每一個(gè)Button的高亮,動(dòng)畫,掛載到每一個(gè)NavigationButton上。
public class NavigationButton: MonoBehaviour { Awake(){ } //按鈕被選中時(shí) public void Select() { //transform.DOScale(new Vector3(1.75f, 1.75f, 0), 0.3f).SetId(transform.name); } //按鈕未被選中時(shí) public void UnSelect() { //DOTween.Kill(transform.name); //transform.DOScale(new Vector3(1.0f, 1.0f, 0), 0.3f).SetId(transform.name); } }
NavigationPanel:
控制面板的顯示和隱藏,掛載到每一個(gè)NavigationPane上。
public class NavigationPanel : MonoBehaviour { //顯示 public void Show() { transform.gameObject.SetActive(true); } //隱藏 public void Hide() { transform.gameObject.SetActive(false); } }
NavigationGroup:
具體邏輯,掛載到NavigationGroup上,拖入button和panel。
public class NavigationGroup: MonoBehaviour { public NavigationButton[] navBtns; //按鈕組 public NavigationPanel[] navPans; //面板組 public int index; //索引 public int length; //長(zhǎng)度 private void Awake() { index = -1; length = navBtns.Length; for (int i = 0; i < length; i++) { navBtns[i].UnSelect(); navPans[i].Hide(); } } //通過索引來顯示被選中后狀態(tài)和對(duì)應(yīng)panel private void OnSelectByIndex() { for (int i = 0; i < length; i++) { if (i == index) { navBtns[i].Select(); navPans[i].Show(); } else { navBtns[i].UnSelect(); navPans[i].Hide(); } } } //點(diǎn)擊按鈕事件 public void OnClickNavBtn(int value) { if (index != value) { index = value; OnSelectByIndex(); } } //初始被選中的按鈕 public void BeginShow(int values = -1) { index = values; OnSelectByIndex(); } //********************************************** //附加:滑動(dòng)屏幕切換頁面 //********************************************** private Vector2 beginPos=new Vector2(0,0); private Vector2 endPos=new Vector2(0,0); private float maxDistance=100; private void Update() { //獲取鼠標(biāo)滑動(dòng)起始坐標(biāo)和終點(diǎn)坐標(biāo) if (Input.GetMouseButtonDown(0)) { beginPos =new Vector2(Input.mousePosition.x, Input.mousePosition.y); } if (Input.GetMouseButtonUp(0)) { endPos = new Vector2(Input.mousePosition.x, Input.mousePosition.y); SlipDirection(); } } //判斷滑的方向 public void SlipDirection() { if (Mathf.Abs(beginPos.y - endPos.y) < (Mathf.Abs(beginPos.x - endPos.x))) { if (Mathf.Abs(beginPos.x - endPos.x) > maxDistance) { if (beginPos.x > endPos.x) { Next(); } else { Prev(); } } } } //向前滑動(dòng)屏幕 public void Prev() { if (index > 0) { index--; OnSelectByIndex(); } } //向后滑動(dòng)屏幕 public void Next() { if(index<length-1) { index++; OnSelectByIndex(); } } }
MainManager:
總控制。
public class MainManager: MonoBehaviour { public NavigationGroup navGroup; Start() { Begin(); } //調(diào)用初始方法 public void Begin() { navGroup.BeginShow(0); } //************************************** //長(zhǎng)時(shí)間沒交互,返回待機(jī)界面 //************************************** public void ReturnStandBy() { navGroup.BeginShow(0); } private void Update() { if (Input.GetMouseButtonDown(0)) { Invoke("ReturnStandBy", 60.0f); } } }
以上,基本導(dǎo)航完成。
可以添加導(dǎo)航界面出現(xiàn)和關(guān)閉時(shí)的動(dòng)畫,在Navigation里添加兩個(gè)函數(shù): NavShow() ,NavHide()
show的時(shí)候記得調(diào)用BeginShow(); 在外面調(diào)用 show 和 hide 即可。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
C#中動(dòng)態(tài)數(shù)組用法實(shí)例
這篇文章主要介紹了C#中動(dòng)態(tài)數(shù)組用法,實(shí)例分析了C#中ArrayList實(shí)現(xiàn)動(dòng)態(tài)數(shù)組的技巧,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2015-04-04C# Socket編程實(shí)現(xiàn)簡(jiǎn)單的局域網(wǎng)聊天器的示例代碼
這篇文章主要介紹了C# Socket編程實(shí)現(xiàn)簡(jiǎn)單的局域網(wǎng)聊天器,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-03-03C#實(shí)現(xiàn)啟動(dòng),關(guān)閉與查找進(jìn)程的方法
這篇文章主要介紹了C#實(shí)現(xiàn)啟動(dòng),關(guān)閉與查找進(jìn)程的方法,通過簡(jiǎn)單實(shí)例形式分析了C#針對(duì)進(jìn)程的啟動(dòng),關(guān)閉與查找的相關(guān)實(shí)現(xiàn)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-11-11C#難點(diǎn)逐個(gè)擊破(4):main函數(shù)
貌似我是在寫C#的學(xué)習(xí)筆記哦,不過反正可以利用這個(gè)機(jī)會(huì)來好好溫習(xí)下基礎(chǔ)知識(shí),這其中很多知識(shí)點(diǎn)都屬于平時(shí)視而見的小知識(shí)2010-02-02WPF實(shí)現(xiàn)Interaction框架的Behavior擴(kuò)展
這篇文章介紹了WPF實(shí)現(xiàn)Interaction框架Behavior擴(kuò)展的方法,文中通過示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-06-06C# Winform程序?qū)崿F(xiàn)防止多開的方法總結(jié)【親測(cè)】
這篇文章主要介紹了C# Winform程序?qū)崿F(xiàn)防止多開的方法,結(jié)合實(shí)例形式總結(jié)分析了C# Winform防止多開相關(guān)操作技巧與使用注意事項(xiàng),需要的朋友可以參考下2020-03-03C#實(shí)現(xiàn)簡(jiǎn)單的文件加密與解密方式
這篇文章主要介紹了C#實(shí)現(xiàn)簡(jiǎn)單的文件加密與解密方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-01-01