前言

本文基于MVC模式,用UGUI初步实现了背包系统。

Control层包括了点击和拖拽两种逻辑。

博文首发:http://blog.csdn.net/duzixi

下载地址:https://github.com/duzixi/InventorySystem

一、project准备(详见project文件)

场景中Canvas上的对象:

  • Bag:用于显示背包内容
  • PickedItem:用于显示拾取道具的图片

资源中的预设体:

  • Item:生成背包的格子

二、源码

Model 层

using UnityEngine;
using UnityEngine.UI;
using System.Collections;
using System.Collections.Generic;
/// <summary>
/// 脚本功能:MVC模式——Model层。定义物品结构,保存物品数据
/// 加入对象:Bag 背包(Canvas下的空对象)
/// 版权声明:Copyright (c) 2015 duzixi.com All Rights Reserved
/// 创建日期:2015.5.8
/// 知识要点:
/// 1. MVC
/// 2. 自己定义类
/// 3. 类的嵌套
/// </summary>
public class ItemModel : MonoBehaviour { // 物品类的定义
public class Item
{
public string name; // 物品名称
public Sprite img; // 物品图片 // 构造器
public Item(string name, Sprite img) {
this.name = name;
this.img = img;
}
} public static List<Item> items; // 保存物品对象的集合 // 物品图片数组
public int size = 16;
Sprite[] sprites; void Awake() // 数据初始化
{
items = new List<Item>(); // 初始化List<Item>
sprites = new Sprite[size]; // 依据行列值初始化物品列表
for (int i = 0; i < BagView.row; i++) {
for (int j = 0; j < BagView.col; j++) {
items.Add(new Item("", null));
}
} // 【注意】实际开发中下面部分应由数据库取代
for (int i = 0; i < size; i++) {
string name = i < 9 ? "0" + (i + 1) : "" + (i + 1);
sprites[i] = Resources.Load(name, typeof(Sprite)) as Sprite;
items[i] = new Item(" ", sprites[i]);
}
}
}

View 层

using UnityEngine;
using UnityEngine.UI;
using System.Collections;
/// <summary>
/// 脚本功能:MVC模式 —— View视图,控制背包的显示方式
/// 加入对象:Bag 背包 (Canvas下的空对象)
/// 版权声明:Copyright (c) 2015 duzixi.com All Rights Reserved
/// 创建时间:2015.05.08
/// 改动记录:2015.05.18 加入编号
/// 改动记录:2015.07.03 封装显示物品行子方法
/// 知识要点:
/// 1. MVC
/// 2. UGUI
/// </summary>
public class BagView : MonoBehaviour {
// 背包规格
public static int row = 4; // 行
public static int col = 5; // 列 // 背包格子
public GameObject grid;
float width; // 格子宽度
float height; // 格子高度 // 依据格子预设体获取宽和高
void Awake() {
width = grid.GetComponent<RectTransform>().rect.width;
height = grid.GetComponent<RectTransform>().rect.height;
} // 初始状态:平铺格子。创建背包
void Start () {
for (int i = 0; i < row; i++) {
for (int j = 0; j < col; j++) {
// 计算ID值(物品列表下标)
int id = j + i * col; // 实例化格子预设,按宽高布局
GameObject itemGrid = Instantiate(grid, transform.position + new Vector3(j * width, -i * height, 0), Quaternion.identity) as GameObject;
// 将实例化的格子对象设置为背包的子对象
itemGrid.transform.SetParent(transform); // 调用自己定义方法:显示某个id的格子内容
ShowItem(itemGrid.transform, id); // 给格子 PickUpDrop 组件编号。拾取放下时用
itemGrid.GetComponent<PickUpDrop>().gridID = id;
}
}
} // 又一次刷新背包显示(物品位置发生变化时)
public void ShowItems() {
for (int i = 0; i < row * col; i++) {
Transform itemGrid = transform.GetChild(i);
ShowItem(itemGrid, i);
}
} // 显示物品行子
private void ShowItem(Transform itemGrid, int id) {
// 显示物品名称
Text txtUGUI = itemGrid.GetComponentInChildren<Text>();
txtUGUI.text = ItemModel.items[id].name; // 获取物品Icon的Image组件
Image imageUGUI = itemGrid.GetChild(0).GetComponent<Image>(); // 假设有物品。就显示图片
if (ItemModel.items[id].img != null) {
imageUGUI.color = Color.white;
} else { // 否则不显示
imageUGUI.color = Color.clear;
}
imageUGUI.sprite = ItemModel.items[id].img;
}
}
using UnityEngine;
using UnityEngine.UI;
using System.Collections;
/// <summary>
/// 脚本功能:让拾取的背包物品随鼠标移动
/// 加入对象:PickedItem 拾取的物品
/// 版权声明:Copyright (c) 2015 duzixi.com All Rights Reserved
/// 创建日期:2015.05.18
/// 改动记录:2015.07.03 加入射线忽略
/// 知识要点:
/// 1. UGUI RectTransform、锚点、中心点
/// 2. 忽略射线接口 ICanvasRaycastFilter
/// </summary> public class MoveWithMouse : MonoBehaviour, ICanvasRaycastFilter {
RectTransform rect; // 获取UGUI定位组件 Image icon; // 显示当前拾取物品的图标 void Awake() {
rect = GetComponent<RectTransform>();
// 【注意】图标对象是第0个子对象
icon = transform.GetChild(0).GetComponent<Image>();
} void Update () {
// 用鼠标位置给图标图片定位
rect.anchoredPosition3D = Input.mousePosition;
// 依据是否有图片确定透明度
if (PickUpDrop.pickedItem.img != null) {
icon.color = Color.white;
} else {
icon.color = Color.clear;
}
icon.sprite = PickUpDrop.pickedItem.img;
} // 忽略鼠标图标上的射线
public bool IsRaycastLocationValid (Vector2 sp, Camera eventCamera) {
return false;
}
}

Control 层

using UnityEngine;
using UnityEngine.EventSystems;
using System.Collections;
/// <summary>
/// 脚本功能:MVC模式 —— Control控制,背包内物品摆放
/// 加入对象:Item 物品行子预设体
/// 版权声明:Copyright (c) 2015 duzixi.com All Rights Reserved
/// 创建日期:2015.05.18 duzixi.com
/// 改动记录:2015.07.03 加入射线忽略
/// 知识要点:
/// 1. UGUI、MVC设计模式
/// </summary>
public class PickUpDrop : MonoBehaviour, IDropHandler {
public int gridID; public static ItemModel.Item pickedItem; // 当前拾取的物品 void Start () {
// 初始化当前拾取物品为空
pickedItem = new ItemModel.Item("", null);
} // 背包核心逻辑:交换
public static void SwapItem(int gridID)
{
// 交换背包中的物品和拾取物品
ItemModel.Item temp = pickedItem;
pickedItem = ItemModel.items[gridID];
ItemModel.items[gridID] = temp; // 刷新背包显示
GameObject.Find("Bag").GetComponent<BagView>().ShowItems();
} // 当物品button被点下时(点击触发模式)
public void Drop() {
SwapItem(gridID);
} // 当物品放在格子中时(拖拽触发模式)
public void OnDrop (PointerEventData eventData) {
SwapItem(gridID);
} }
using UnityEngine;
using UnityEngine.UI;
using UnityEngine.EventSystems;
using System.Collections;
/// <summary>
/// 脚本功能:MVC模式 —— Control控制。操作逻辑。拖拽事件处理
/// 加入对象:Bag 背包 (Canvas下的空对象)
/// 版权声明:Copyright (c) 2015 duzixi.com All Rights Reserved
/// 创建时间:2015.07.03
/// 知识要点:
/// 1. UnityEngine.EventSystem
/// 2. IBeginDragHandlder, IDragHandler, IEndDragHander
/// </summary>
public class DragEvent : MonoBehaviour,IBeginDragHandler,IDragHandler,IEndDragHandler { int gridID = 0; // 格子编号 void Start() {
gridID = GetComponentInParent<PickUpDrop>().gridID; // 获取格子编号
} // 開始拖拽
public void OnBeginDrag (PointerEventData eventData) {
// 调用交换方法
PickUpDrop.SwapItem(gridID);
} // 拖拽中
public void OnDrag (PointerEventData eventData) {
// 【注意】即使没有不论什么代码处理也要实现该接口。否则拖拽不成功
} // 结束拖拽
public void OnEndDrag (PointerEventData eventData) {
// 调用交换方法
PickUpDrop.SwapItem(gridID);
} }

后语

眼下还有点Bug。拖拽模式下当前物体拖拽会导致物品尾随。

另外屏幕适配还没有搞。



【Unity】基于MVC模式的背包系统 UGUI实现的更多相关文章

  1. struts1:(Struts重构)构建一个简单的基于MVC模式的JavaWeb

    在构建一个简单的基于MVC模式的JavaWeb 中,我们使用了JSP+Servlet+JavaBean构建了一个基于MVC模式的简单登录系统,但在其小结中已经指出,这种模式下的Controller 和 ...

  2. 构建一个简单的基于MVC模式的JavaWeb

    零晨三点半了,刚刚几个兄弟一起出去吼歌,才回来,这应该是我大学第二次去K歌,第一次是大一吧,之后每次兄弟喊我,我都不想去,因为我还是很害怕去KTV,或许是因为那里是我伤心的地方,也或许是因为我在那里失 ...

  3. Unity之MVC 模式

    MVC 模式代表 Model-View-Controller(模型-视图-控制器) 模式.这种模式用于应用程序的分层开发. Model(模型) - 模型代表一个存取数据的对象或 JAVA POJO.它 ...

  4. unity 使用MVC模式

    这两天看了下老大的项目,他基本都是用MVC模式,写的很好,在此把我理解的记录下来 Model:实体对象(对应数据库记录的类) View:视图 presenter(controller):业务处理 vi ...

  5. 基于MVC模式的应用框架之struts

    1.struts开发步骤 引入struts的jar包: 在web.xml中引入struts的核心功能,配置struts核心过滤器:(如果项目中用到了其他过滤器,要放在struts过滤器之前,否则会失效 ...

  6. 基于MVC模式的数据库综合练习

    一.准备 没什么好说的,直接上代码.... 下面是web.xml <servlet> <servlet-name>list_user</servlet-name> ...

  7. 基于MVC模式开发的后台框架

    1.ThinkCMF 2.NFine快速开发平台 3.力软快速开发框架 如有好的开发框架希望可以一起交流

  8. 基于 Dojo toolkit 实现 web2.0 的 MVC 模式

    前言 MVC 模式是设计模式中的经典模式,它可以有效的分离数据层,展示层,和业务逻辑层.Web2.0 技术由于其良好的用户体验被广泛应用于 WEB 应用的展示层.但是在传统的 web 开发中,展示层的 ...

  9. 传统的MVC模式

    对于MVC模式,我们可以将可视化UI呈现,UI处理逻辑和业务逻辑分别定义在View,Controller,和Model中. 可视化UI呈现->View UI处理逻辑->Controller ...

随机推荐

  1. win7上搭建ruby开发环境

    1. 安装ruby 可使用windows下的ruby安装工具rubyinstaller来方便地安装ruby解释器,可以http://rubyinstaller.org/网站上下载得到.安装时,看清安装 ...

  2. HDU 2819 Swap (行列匹配+输出解)

    题意:是否能使对角线上全是1 ,这个简单直接按行列匹配.难在路径的输出,我们知道X,Y左右匹配完了之后,不一定是1–1,2–2,3–3--这种匹配.可能是1–3,2–1,3–2,我们要把他们交换成前一 ...

  3. iOS 核心动画 Core Animation浅谈

    代码地址如下:http://www.demodashi.com/demo/11603.html 前记 关于实现一个iOS动画,如果简单的,我们可以直接调用UIView的代码块来实现,虽然使用UIVie ...

  4. Quartz.net基于数据库的任务调度管理(Only.Jobs)

    一 前言: 各大调度组件优缺点在这就不讨论了,使用Quartz.net是因为它可以执行秒级任务. Only.Jobs 项目通过将各Job存储在数据库中,启动一个专门的Job管理任务来循环调度各Job的 ...

  5. 在php中如何用 union all统计总条数?

    网上使用union all 查询记录总条数的参考资料比较少,所以记录下来,以便有同样需求的人使用. $rs_num = Db::query("select sum(a.b) as num f ...

  6. AMD 3600+ X2 CPU配合昂达A69T主板超频教程

    本次超频使用电脑硬件配置如下: AMD 3600+ X2 90nm 昂达 A69T HDMI 宇瞻 DDR II 1G 667普条 西数 WD2500KS SATAII  250G 16M 戴尔 普通 ...

  7. numpy, pandas, scikit-learn cheat sheet (速查表)

    1. scikit-learn cheat sheet 官方链接如下:http://scikit-learn.org/stable/tutorial/machine_learning_map/ Oft ...

  8. Linux入门常用指令

    linux获取硬盘和目录大小的命令 df命令 Linux下可以用df命令获取硬盘的使用情况,通过man可以获取df命令的详细情况.df命令经常用的参数为: a:显示全部的档案系统和各分割区的磁盘使用情 ...

  9. Vivado 与 Modelsim 联合仿真

    1 编译库 用命令行 用vivado工具 vivado 有很多 IP核的接口 已经与 ISE的核 不太一样了,比如fir ,接口就是这样的: fir_lp fir_lp_ip(    .aclk  ( ...

  10. 李洪强经典面试题51-KVO-KVC

    李洪强经典面试题51-KVO-KVC   KVC-KVO KVC的底层实现? 当一个对象调用setValue方法时,方法内部会做以下操作: ①检查是否存在相应key的set方法,如果存在,就调用set ...