分段经验条制作

一.UI制作

1.调整Canvas的参数
在这里插入图片描述
2.新建屏幕大小与References Resolution对应。
在这里插入图片描述
3.创建空物体,命名为Buttom_UI
在这里插入图片描述

4.制作经验标识图片
在这里插入图片描述
5.制作经验背景图片在这里插入图片描述
6.在背景图片下创建空物体item_list,并添加GridLayoutGroup组件。
在这里插入图片描述
7.在item_list下创建经验条,并复制九份。注意要改成fill模式
在这里插入图片描述

8.调整GridLayoutGroup组件的参数。
在这里插入图片描述

二.添加脚本

现在的分段经验条只能在标准模式下适配,一旦屏幕大小出现变化就会出现拉伸变形。所以我们需要动态的改变GridLayoutGroup组件的cellSize.x属性,以达到自适应的效果。

通过观察,我们发现我们只需要用 (屏幕宽度-图片上的红色地方)/10就可以得到每个分段经验条的尺寸。
在这里插入图片描述
(1)计算红色部分

1的大小为58
在这里插入图片描述
2的大小为10
在这里插入图片描述
3.的大小为16
在这里插入图片描述
4-12:查看GridLayoutGroup的Spacing.x属性(10*9)

然后一共加起来就是58+10+16+10*9=174.
(2)写脚本

using System.Collections;
using System.Collections.Generic;
using UnityEngine;
using UnityEngine.UI;
 
public class MainCityWnd : WinBase {



    public Transform expPrgTrans;//item_list


    public void Start()
    {
        RefreshUI();
    }
//1.经验条自适应
    private void RefreshUI()
    {
    
        GridLayoutGroup gridLayoutGroup = expPrgTrans.GetComponent<GridLayoutGroup>();

        //由于我们的Canvas选择的是Scale with Screen Size,且Match为1,也就是UI受高度影响到大
        //所以屏幕的实际宽度= 获取到的宽度*缩放
        float globalRate = 1.0F * Constants.ScreenStandardHight / Screen.height;
        float Screenwidth = Screen.width * globalRate;
        float width = (Screenwidth - 174) /10;
        gridLayoutGroup.cellSize = new Vector2(width, 7);
    }
//经验条填充
private void ExpUpate()
    {
        PlayData pd = GameRoot.Instance.Playedata;

        int expPrgVal;//(当前经验/升级经验)*100
        int index = expPrgVal / 10;
        for (int i = 0; i < expPrgTrans.childCount; i++)
        {
            Image image = expPrgTrans.GetChild(i).GetComponent<Image>();
            if (i < index)
            {
                image.fillAmount = 1;
            }
            else if (i == index)
            {
                image.fillAmount = (expPrgVal % 10) * 0.1f;
            }
            else
            { image.fillAmount = 0; }
        }
    }
 
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值