标签:
unity的LayoutGroup分为三种, Horizontal Layout Group(水平布局)Vertical Layout Group(垂直布局)Grid Layout Group (网格布局)
Grid Layout Group
如果单纯的时候用滑动效果可以使用Scroll Rect组件即可。但使用布局就要使用布局控件
Grid Layout Group是网格布局,先看看一个效果
其实滑动依然是用的Scroll Rect。这个就不说了。这里主要说布局。
Spacing 表示 cell之间的距离。
Cell表示格子的宽度和和高度
Start Axis 表示布局方式,有横向和纵向
Child Alignment 表示对齐方式。
注意Layout Group节点下面的所有cell节点都是不能修改Rect Transform的。因为cell可能下面会放很多图片,这样我们会用个空的gameObject来当父节点。
但你仔细看。会发现。这个不是整块滑动的。比如手机屏幕左右滑动,是滑动区域判断的。没有划过来的时候。会退回去。像这样
这里可以根据Scroll Rect组件的normalizedPosition属性来判断。这是一个Vector2坐标。是滑动中XY的值
horizontalNormalizedPosition:水平的值
verticalNormalizedPosition:垂直的值
需要在拖动结束后判断。需要继承
IBeginDragHandler,IEndDragHandler。引用命名空间:using UnityEngine.EventSystems;
具体代码:
using UnityEngine; using System.Collections; using UnityEngine.EventSystems; using UnityEngine.UI; public class newScroll : MonoBehaviour, IBeginDragHandler, IEndDragHandler { ScrollRect rect; //页面:0,1,2 索引从0开始 //每夜占的比列:0/2=0 1/2=0.5 2/2=1 float[] page = { 0, 0.5f, 1 }; //滑动速度 public float smooting = 4; //滑动的起始坐标 float targethorizontal = 0; //是否拖拽结束 bool isDrag = false; // Use this for initialization void Start() { rect = transform.GetComponent<ScrollRect>(); } // Update is called once per frame void Update() { //如果不判断。当在拖拽的时候要也会执行插值,所以会出现闪烁的效果 //这里只要在拖动结束的时候。在进行插值 if (!isDrag) { rect.horizontalNormalizedPosition = Mathf.Lerp(rect.horizontalNormalizedPosition, targethorizontal, Time.deltaTime * smooting); } } /// <summary> /// 拖动开始 /// </summary> /// <param name="eventData"></param> public void OnBeginDrag(PointerEventData eventData) { isDrag = true; } /// <summary> /// 拖拽结束 /// </summary> /// <param name="eventData"></param> public void OnEndDrag(PointerEventData eventData) { isDrag = false; // //拖动停止滑动的坐标 // Vector2 f = rect.normalizedPosition; // //水平 开始值是0 结尾值是1 [0,1] // float h = rect.horizontalNormalizedPosition; // //垂直 // float v = rect.verticalNormalizedPosition; float posX = rect.horizontalNormalizedPosition; int index = 0; //假设离第一位最近 float offset = Mathf.Abs(page[index] - posX); for (int i = 1; i < page.Length; i++) { float temp = Mathf.Abs(page[i] - posX); if (temp < offset) { index = i; //保存当前的偏移量 //如果到最后一页。反翻页。所以要保存该值,如果不保存。你试试效果就知道 offset = temp; } } /* 因为这样效果不好。没有滑动效果。比较死板。所以改为插值 */ //rect.horizontalNormalizedPosition = page[index]; targethorizontal = page[index]; } }
标签:
原文地址:http://www.cnblogs.com/nsky/p/4854002.html