热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

UI的重用性

UI抽取思路一款手机游戏中UI有几十个到上百个不等,如果一个一个做这些UI,无疑会花费很多时间。近期我们的游戏UI已经是第N次改版了,经过

UI抽取思路

一款手机游戏中UI有几十个到上百个不等,如果一个一个做这些UI,无疑会花费很多时间。

近期我们的游戏UI已经是第N次改版了,经过这N多次的修改,我总结了UI其实有很多的共性(就是相同性)。

下面说一些我觉得常用的UI的抽取思路

 

共用按钮

image

共同点:按钮,标题,[图标],[消息数提醒]

思路分析

按钮点击事件和标题是一定有的,其它的视情况而定。所以我们可以创建一个类 BtnItemClass,用来处理UI的逻辑,外部就只要传入相应的参数就可

 

共用组件

using System;
using UnityEngine;
using System.Collections;///


/// 共用的图文按钮,抽取类
/// 包括:商店,挑战,朋友,英雄
///

public class BtnItemClass
{
public string TitleSprite;public string IconSprite;public string BtnName;public string NextUITitle;//按钮点击的事件public UIEventListener.VoidDelegate Callback;//消息提醒数public string TipMsg;public int TipNum;private bool IsEnabled;/// /// 构造函数/// /// 按钮名/// Item 图标/// 标题文字图片,没有就填null/// 下一级UI的标题/// 点击的事件/// public BtnItemClass(string btnName, string iconSprite, string titleSprite, string nextUiTitle, UIEventListener.VoidDelegate callback, bool enabled = true){this.BtnName = btnName;this.IconSprite = iconSprite ?? "null";this.TitleSprite = titleSprite ?? "null";this.NextUITitle = nextUiTitle;this.Callback = callback;IsEnabled = enabled;} public BtnItemClass()

{

}

//设置属性public static void Bind(BtnItemClass itemClass, Transform trans){if(!string.IsNullOrEmpty( itemClass.BtnName))trans.name = itemClass.BtnName;//标题文字图片UISprite titleSprite = CTool.GetChildComponent("TitleSprite", trans);titleSprite.spriteName = itemClass.TitleSprite;titleSprite.MakePixelPerfect();//图标UISprite iconSprite = CTool.GetChildComponent("IconSprite", trans);iconSprite.spriteName = itemClass.IconSprite;iconSprite.MakePixelPerfect();//当标题图片找不到时就显示文字var titleLabel = CTool.GetChildComponent("TitleLabel", trans);if (string.IsNullOrEmpty(itemClass.TitleSprite)|| itemClass.TitleSprite == "null"){titleLabel.text = itemClass.NextUITitle;titleLabel.gameObject.SetActive(true);}else{titleLabel.gameObject.SetActive(false);}//绑定事件trans.GetComponent().onClick = itemClass.Callback;//button.isEnabled = item.IsEnable = item.IsEnable;
}
}

使用方法

首先构建一个List,里面里包含当前的UI所有按钮的数据,然后做刷新UI(生成按钮,设置按钮属性)

//按钮数据
private List UIConfigList
{
get{return new List(){new BtnItemClass("BtnHeroList", "BattleTeam_icon_HeroStrong", "null", "英雄强化",obj => CNetPlayer.CheckPackageOverflow_WithMsgBox(() => CUIHeroList.Show("英雄强化"))),new BtnItemClass( "武器强化,obj => CUIPowerUp.ShowWeaponstSelectList()),
};}
}
//刷新UI
private void RefreshUI()
{
var max = UIConfigList.Count;CUIHelper.ResizeCUITableGridGameObjects(TableGrid, max, CommPicBtnTemplate);for (int idx = 0; idx ){var trans = TableGrid.transform.GetChild(idx);var itemClass = UIConfigList[idx]; BtnItemClass.Bind(itemClass, trans);}TableGrid.Reposition();
}




推荐阅读
  • 在前文探讨了Spring如何为特定的bean选择合适的通知器后,本文将进一步深入分析Spring AOP框架中代理对象的生成机制。具体而言,我们将详细解析如何通过代理技术将通知器(Advisor)中包含的通知(Advice)应用到目标bean上,以实现切面编程的核心功能。 ... [详细]
  • WPF项目学习.一
    WPF项目搭建版权声明:本文为博主初学经验,未经博主允许不得转载。一、前言记录在学习与制作WPF过程中遇到的解决方案。使用MVVM的优点是数据和视图分离,双向绑定,低耦合,可重用行 ... [详细]
  • PBO(PixelBufferObject),将像素数据存储在显存中。优点:1、快速的像素数据传递,它采用了一种叫DMA(DirectM ... [详细]
  • 目录预备知识导包构建数据集神经网络结构训练测试精度可视化计算模型精度损失可视化输出网络结构信息训练神经网络定义参数载入数据载入神经网络结构、损失及优化训练及测试损失、精度可视化qu ... [详细]
  • VB.net 进程通信中FindWindow、FindWindowEX、SendMessage函数的理解
    目录一、代码背景二、主要工具三、函数解析1、FindWindow:2、FindWindowEx:3、SendMessage: ... [详细]
  • 重要知识点有:函数参数默许值、盈余参数、扩大运算符、new.target属性、块级函数、箭头函数以及尾挪用优化《深切明白ES6》笔记目次函数的默许参数在ES5中,我们给函数传参数, ... [详细]
  • 深入解析 Lifecycle 的实现原理
    本文将详细介绍 Android Jetpack 中 Lifecycle 组件的实现原理,帮助开发者更好地理解和使用 Lifecycle,避免常见的内存泄漏问题。 ... [详细]
  • 在Delphi7下要制作系统托盘,只能制作一个比较简单的系统托盘,因为ShellAPI文件定义的TNotifyIconData结构体是比较早的版本。定义如下:1234 ... [详细]
  • 本文介绍了 .NET 中用于线程间通信的工具 WaitHandle 及其子类 ManualResetEvent 和 AutoResetEvent,并详细解释了线程池的概念及其在优化资源利用方面的优势。 ... [详细]
  • 利用REM实现移动端布局的高效适配技巧
    在移动设备上实现高效布局适配时,使用rem单位已成为一种流行且有效的技术。本文将分享过去一年中使用rem进行布局适配的经验和心得。rem作为一种相对单位,能够根据根元素的字体大小动态调整,从而确保不同屏幕尺寸下的布局一致性。通过合理设置根元素的字体大小,开发者可以轻松实现响应式设计,提高用户体验。此外,文章还将探讨一些常见的问题和解决方案,帮助开发者更好地掌握这一技术。 ... [详细]
  • 开发技巧:在Interface Builder中实现UIButton文本居中对齐的方法与步骤
    开发技巧:在Interface Builder中实现UIButton文本居中对齐的方法与步骤 ... [详细]
  • 在《Cocos2d-x学习笔记:基础概念解析与内存管理机制深入探讨》中,详细介绍了Cocos2d-x的基础概念,并深入分析了其内存管理机制。特别是针对Boost库引入的智能指针管理方法进行了详细的讲解,例如在处理鱼的运动过程中,可以通过编写自定义函数来动态计算角度变化,利用CallFunc回调机制实现高效的游戏逻辑控制。此外,文章还探讨了如何通过智能指针优化资源管理和避免内存泄漏,为开发者提供了实用的编程技巧和最佳实践。 ... [详细]
  • 在 Vue 应用开发中,页面状态管理和跨页面数据传递是常见需求。本文将详细介绍 Vue Router 提供的两种有效方式,帮助开发者高效地实现页面间的数据交互与状态同步,同时分享一些最佳实践和注意事项。 ... [详细]
  • 设计实战 | 10个Kotlin项目深度解析:首页模块开发详解
    设计实战 | 10个Kotlin项目深度解析:首页模块开发详解 ... [详细]
  • C#中实现高效UDP数据传输技术
    C#中实现高效UDP数据传输技术 ... [详细]
author-avatar
人对方啥地位
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有