Unity UGUI 效果 之 Scroll 根据内容多少,动态实现鼠标滑动滚动浏览预览( Scrollbar + ScrollRect + XXLayoutGroup)

本文主要是介绍Unity UGUI 效果 之 Scroll 根据内容多少,动态实现鼠标滑动滚动浏览预览( Scrollbar + ScrollRect + XXLayoutGroup),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

 

 

Unity UGUI 效果 之  Scroll 根据内容多少,动态实现鼠标滑动滚动浏览预览( Scrollbar + ScrollRect + XXLayoutGroup)

 

目录

Unity UGUI 效果 之  Scroll 根据内容多少,动态实现鼠标滑动滚动浏览预览( Scrollbar + ScrollRect + XXLayoutGroup)

一、简单介绍

二、实现原理

三、注意实现

四、效果预览

五、实现步骤

六、关键代码

附录方法二:使用 Vertical Layout Group + Content Size Fitter 无需代码轻松实现滚动预览


 

一、简单介绍

UGUI,是Unity自带的 GUI 系统,有别于 NGUI;使用 UGUI 也能制作出比较酷炫的效果 。

本节介绍,使用 UGUI 通过代码实现在内容变化不定的情况下,动态调整Scroll等,实现可以鼠标拖动预览的效果,方法不唯一,欢迎指正。

 

二、实现原理

1、ScrollRect、Scrollbar,实现可鼠标滑动滚动功能

2、Mask 遮罩多余的内容

3、XXLayoutGroup 方便排布内容

 

三、注意实现

1、XXLayoutGroup  组件的 Pivot ,根据需要设定位置(例如内容向下增长,即最好Pivot 设置在中上处,(0.5,1)位置为宜)

2、这里只是实现了垂直方向的滚动滑动浏览,水平方向同理,大家可以自行实现哈

 

四、效果预览

 

五、实现步骤

1、打开Unity,新建一个工程

 

2、添加一个 Image,最为 ScrollRect 背景,Scrollbar 动态滚动滑动使用,这里GameObject,添加 VerticalLayoutGroup,垂直布局

 

3、ScrollRectDynamicHeight_Image,添加 Mask ,ScrollRect 组件,并对应赋值

 

4、ItemsContent_VerticalLayoutGroup 设置如下,根据需要设置,不唯一

 

5、Scrollbar 合理调整大小,设置可以默认,不唯一

 

6、Item_Image 作为 ItemsContent_VerticalLayoutGroup  的 item 条目,这里只是示范,根据具体内容指定哈

 

7、新建脚本,实现动态内容滚动滑动预览的功能

 

8、ScrollVerticalDynamicHeightRect

 

9、运行场景,效果如上

 

六、关键代码

1、ScrollVerticalDynamicHeightRect

using System.Collections;
using System.Collections.Generic;
using UnityEngine;
using UnityEngine.UI;namespace XANTools
{public class ScrollVerticalDynamicHeightRect : MonoBehaviour{// 设置获取相关参数public Transform ItemsContent_VerticalLayoutGroup;// Item 预制体public GameObject itemImagePrefab;// ScrollRect 对象(动态激活他,看情况使用)public ScrollRect scrollRect;// GridVertical 物体的原始大小private Vector2 originSize;// Use this for initializationvoid Start(){//获取最初goParent的宽高originSize = ItemsContent_VerticalLayoutGroup.GetComponent<RectTransform>().sizeDelta;}// Update is called once per framevoid Update(){//按下空格键调用添加ItemImageif (Input.GetKeyDown(KeyCode.Space)){// 随机增加若干个 ItemAddScrollItem(Random.Range(1,5));}}/// <summary>/// 生成指定数量 Item,实现动态调整 Scroll /// </summary>/// <param name="count"></param>private void AddScrollItem(int count){//生成ItemImagefor (int i = 0; i < count; i++){GameObject go = Instantiate(itemImagePrefab) as GameObject;go.transform.SetParent(ItemsContent_VerticalLayoutGroup);}//调整ScrollRect边框大小//获取当前的ItemImage的实际个数int itemImageCount = ItemsContent_VerticalLayoutGroup.childCount;//计算当前实际生成ItemImage所需要的goParent的高度float ScrollRectY = itemImageCount * ((itemImagePrefab.GetComponent<RectTransform>().sizeDelta.y)+ ItemsContent_VerticalLayoutGroup.GetComponent<VerticalLayoutGroup>().spacing);//比原先小则,保持原有尺寸不变,反之,高度设置为所需要的if (ScrollRectY <= originSize.y){ItemsContent_VerticalLayoutGroup.GetComponent<RectTransform>().sizeDelta = originSize;// 不必要激活可滚动浏览scrollRect.enabled = false;}else{ItemsContent_VerticalLayoutGroup.GetComponent<RectTransform>().sizeDelta = new Vector2(originSize.x, ScrollRectY);// 激活可滚动浏览scrollRect.enabled = true;}}}
}

 

附录方法二:使用 Vertical Layout Group + Content Size Fitter 无需代码轻松实现滚动预览

原理简述:Content Size Fitter 会自动根据Vertical Layout Group 的子物体的多少自动调整 Vertical Layout Group 的整体大小,然后再 Scroll 实现滚动预览

1、在场景中添加一个Image,调整大小,挂载 ScrollRect 和 Mask ,把 LayoutContent 和 Scrollbar 对应赋值

 

2、Layout Content 添加 VerticallayoutGroup 和 Content Size Fitter ,其中 Content Size Fitter 的对应属性 vertical Fit (根据需要对应设置) Preferred Size ,这样 Layout Content 大小就会随着子物体的多少自动调整大小了

 

3、Scrollbar UGUI 自带的UI组件,无需做其他修改,只是把滚动预览方向改为竖直即可

 

4、Layout Content 子物体,根据需要添加好,运行场景,效果如下

 

5、注意,如果Layout Content每次添加子物体,预览总从中部开始,可以调整Pivot 为(0.5,1),调整一次

Layout Content 的边框位置,下次添加子物体和预览就不会从中部开始了

 

 

 

这篇关于Unity UGUI 效果 之 Scroll 根据内容多少,动态实现鼠标滑动滚动浏览预览( Scrollbar + ScrollRect + XXLayoutGroup)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/239274

相关文章

Flutter实现文字镂空效果的详细步骤

《Flutter实现文字镂空效果的详细步骤》:本文主要介绍如何使用Flutter实现文字镂空效果,包括创建基础应用结构、实现自定义绘制器、构建UI界面以及实现颜色选择按钮等步骤,并详细解析了混合模... 目录引言实现原理开始实现步骤1:创建基础应用结构步骤2:创建主屏幕步骤3:实现自定义绘制器步骤4:构建U

SpringBoot中四种AOP实战应用场景及代码实现

《SpringBoot中四种AOP实战应用场景及代码实现》面向切面编程(AOP)是Spring框架的核心功能之一,它通过预编译和运行期动态代理实现程序功能的统一维护,在SpringBoot应用中,AO... 目录引言场景一:日志记录与性能监控业务需求实现方案使用示例扩展:MDC实现请求跟踪场景二:权限控制与

Android实现定时任务的几种方式汇总(附源码)

《Android实现定时任务的几种方式汇总(附源码)》在Android应用中,定时任务(ScheduledTask)的需求几乎无处不在:从定时刷新数据、定时备份、定时推送通知,到夜间静默下载、循环执行... 目录一、项目介绍1. 背景与意义二、相关基础知识与系统约束三、方案一:Handler.postDel

慢sql提前分析预警和动态sql替换-Mybatis-SQL

《慢sql提前分析预警和动态sql替换-Mybatis-SQL》为防止慢SQL问题而开发的MyBatis组件,该组件能够在开发、测试阶段自动分析SQL语句,并在出现慢SQL问题时通过Ducc配置实现动... 目录背景解决思路开源方案调研设计方案详细设计使用方法1、引入依赖jar包2、配置组件XML3、核心配

使用Python实现IP地址和端口状态检测与监控

《使用Python实现IP地址和端口状态检测与监控》在网络运维和服务器管理中,IP地址和端口的可用性监控是保障业务连续性的基础需求,本文将带你用Python从零打造一个高可用IP监控系统,感兴趣的小伙... 目录概述:为什么需要IP监控系统使用步骤说明1. 环境准备2. 系统部署3. 核心功能配置系统效果展

Python实现微信自动锁定工具

《Python实现微信自动锁定工具》在数字化办公时代,微信已成为职场沟通的重要工具,但临时离开时忘记锁屏可能导致敏感信息泄露,下面我们就来看看如何使用Python打造一个微信自动锁定工具吧... 目录引言:当微信隐私遇到自动化守护效果展示核心功能全景图技术亮点深度解析1. 无操作检测引擎2. 微信路径智能获

Python中pywin32 常用窗口操作的实现

《Python中pywin32常用窗口操作的实现》本文主要介绍了Python中pywin32常用窗口操作的实现,pywin32主要的作用是供Python开发者快速调用WindowsAPI的一个... 目录获取窗口句柄获取最前端窗口句柄获取指定坐标处的窗口根据窗口的完整标题匹配获取句柄根据窗口的类别匹配获取句

在 Spring Boot 中实现异常处理最佳实践

《在SpringBoot中实现异常处理最佳实践》本文介绍如何在SpringBoot中实现异常处理,涵盖核心概念、实现方法、与先前查询的集成、性能分析、常见问题和最佳实践,感兴趣的朋友一起看看吧... 目录一、Spring Boot 异常处理的背景与核心概念1.1 为什么需要异常处理?1.2 Spring B

Python位移操作和位运算的实现示例

《Python位移操作和位运算的实现示例》本文主要介绍了Python位移操作和位运算的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录1. 位移操作1.1 左移操作 (<<)1.2 右移操作 (>>)注意事项:2. 位运算2.1

如何在 Spring Boot 中实现 FreeMarker 模板

《如何在SpringBoot中实现FreeMarker模板》FreeMarker是一种功能强大、轻量级的模板引擎,用于在Java应用中生成动态文本输出(如HTML、XML、邮件内容等),本文... 目录什么是 FreeMarker 模板?在 Spring Boot 中实现 FreeMarker 模板1. 环