Unity UGUI 分页滑动

2016-10-04 13:45:21

 1 using UnityEngine;
 2 using System.Collections;
 3 using UnityEngine.EventSystems;
 4 using System;
 5 using UnityEngine.UI;
 6 public class LevelButtonScrollRect : MonoBehaviour, IBeginDragHandler, IEndDragHandler
 7 {
 8     private ScrollRect scrollRect;
 9     private float[] pageArray = new float[] { 0, 0.333f, 0.666f, 1 };
10     public Toggle[] ToggleArray;
11     private float speed = 5f;
12     private float targetHorizontalPosition = 0f;
13     private bool isDraging = false;
14     void Start()
15     {
16         scrollRect = transform.GetComponent<ScrollRect>();
17     }
18
19     void Update()
20     {
21         if (!isDraging)
22         {
23             scrollRect.horizontalNormalizedPosition = Mathf.Lerp(scrollRect.horizontalNormalizedPosition,
24             targetHorizontalPosition, Time.deltaTime * speed);
25         }
26        
27     }
28     public void OnBeginDrag(PointerEventData eventData)
29     {
30         isDraging = true;
31     }
32     public void OnEndDrag(PointerEventData eventData)
33     {
34         isDraging = false;
35         // 得到 水平滑动的 值  (0-1)
36         float posX = scrollRect.horizontalNormalizedPosition;
37         int index = 0;
38         float offset = Mathf.Abs(posX - pageArray[index]);
39         // 与 前后比较 距离最短
40         for (int i = 1; i < pageArray.Length; i++)
41         {
42             // 距离 最短
43             float offsetTemp = Mathf.Abs(posX - pageArray[i]);
44             if (offset > offsetTemp)
45             {
46                 index = i;
47                 offset = offsetTemp;
48             }
49         }
50         targetHorizontalPosition = pageArray[index];
51         ToggleArray[index].isOn = true;
52     }
53 }
时间: 2024-10-13 05:06:55

Unity UGUI 分页滑动的相关文章

unity UGUI动态滑动列表

步骤: 1.在SceneMail创建一个Panel 改名为ScrollRect,ScrollRect添加Mask和Scroll Rect组件,Scroll Rect组件勾选Vertical 只需要垂直滚动 2.在SceneMail创建一个Scrollbar控件 3.ScrollRect上添加子控件Panel 改名为ScorllView,ScorllView大小覆盖ScrollRect 4.ScorllView添加子控件Panel 改名为Content,Content大小覆盖ScorllView

Unity UGUI —— 无限循环List

还记得大学毕业刚工作的时候是做flash的开发,那时候看到别人写的各种各样的UI组件就非常佩服,后来自己也慢慢尝试着写,发现其实也就那么回事.UI的开发其实技术的成分相对来说不算多,但是一个好的UI是绝对少不了底层组件的支持的.我个人认为UI组件中相对比较复杂的就是List了,所以,这两天实现了一个UGUI的list,写了好几个版本,最终这个版本是相对比较好用的,在这我介绍一下大概思路,一是巩固一下知识做个记录,二是发扬一下分享精神.嘿嘿,大家多多赐教. 写List有两个重点是需要考虑的: 1.

制作一个简易的UGUI无限滑动框(Unity)

市面上有很多这种无限拖拽的插件 但是功能细化的太严重了 改的话有些耗时 如果没有太多严苛的需求没必要改工程量比较大的插件 完全可以自己写一个 using System.Collections; using System.Collections.Generic; using UnityEngine; using UnityEngine.UI; public class ItemRect { public Rect mRect; //格子的索引 因为是用来关联位置的 所以不存在删除或修改操作 pub

unity ugui消息透传

公司要做一个这东西. A是滑动区域,ScrollRect组件. B是各种选项. C是拾取到鼠标(或触点)的选项. D是拖放区域. 大概要求是这样. 因为B的条目很多,放在A里可以滑动查看.如果要选择一个B,需要长按B,待时间足够之后生产一个新的C.拖动到D区域释放,则给D添加一个节点.其他区域则取消. 如果按住B的时间不够长,又动了鼠标(或触点),则当前滑动操作由A响应,产生A的滑动效果. 这里涉及到一个消息透传的问题. 解释一下自己在做的过程中采用的2个方案以及各自问题. 涉及的函数有以下几个

Unity UGUI Canvas 使用Slider制作角色血条

最近课程实训选修Unity,讲解的是Unity官方案例--SpaceShoot,培训无聊,便想着给游戏角色制作一下血条,以此增加游戏的可玩性. Unity版本:5.4.1 案例模版:太空射击 原文作者:茄阁云云 原文连接:http://www.cnblogs.com/vmoor2016/p/6044941.html 把一个大象装进冰箱里需要三步:①把冰箱门打开:②把大象塞冰箱里:③关上冰箱门. 那么制作一个角色的血条需要几部呢?在这里也划分为三步:①制作血条:②摆放血条:③操作血条. 下面就来给

unity ugui屏幕适配

1.unity分为2D和3D两种模式,分别对应camera组件的Projection选项,如果是Perspective,就是透视投影(3D模式),如果是Orthographic,就是正交投影(2D模式): 2.unity自带的ugui当中Canvas对象下的Canvas组件当中的Render Mode选项为Screen Space - Overlay时,消耗的draw call相对较少: 3.unity自带的ugui当中Canvas对象下的Canvas Scaler组件的Reference Pi

Unity UGUI 下拉菜单

1.新建Buttom 2.panel里面加下拉buttom using UnityEngine; using System.Collections; public class DropDownList : MonoBehaviour { public GameObject panel; void Start () { panel.SetActive (false); }public void HideOrShow() { panel.SetActive (!panel.activeSelf);

listView的分页滑动

1.         ListView分页加载实现思路 实现OnScrollListener 接口重写onScrollStateChanged 和onScroll方法,使用onscroll方法实现”滑动“后处理检查是否还有新的记录,如果有,调用 addFooterView,添加记录到adapter, adapter调用 notifyDataSetChanged 更新数据;如果没有记录了,把自定义的mFooterView去掉.使用onScrollStateChanged可以检测是否滚到最后一行且停

实现Android4.4系统设置分页滑动浏览功能

需求描述: 由于手机功能越来越完善,相应的偏好设置也就越来越多:从用户体验的角度考虑,为了让用户能够在短时间内对常用的偏好设置进行操作,如WIFI,蜂窝数据等.单独将一些常用的设置功能单独展示出来,已达到减少用户操作的可能性.因此采用将系统设置页面进行分页展示并可以滑动进行切换. 效果图:            对于了解Settings源码的同学应该知道,Settings的设计相对来说并不是很简单,大刀阔斧的对Settings可能会引起更多的bug.因此若实现该需求则在保持原有Settings功