学习游戏制作记录(制作系统与物品掉落系统)8.16

1.制作系统

在游戏里我们可以通过材料来制作装备,当我们点击合成表中的装备时,它会检测我们是否有足够的材料数量来制作

创建相应的物品槽

ItemData_Equipment脚本:

[Header("Crafting Requiring")]
public List<InventoryItem> craftingMaterials;//需要材料的列表

Inventory脚本:

public bool canCraft(ItemData_Equipment _itemToCraft,List<InventoryItem> _requireMaterials)//是否可以制作
{
List<InventoryItem> MaterialToRemove = new List<InventoryItem>();//用来保存删除的材料

for(int i =0;i<_requireMaterials.Count;i++)
{
if (stashItemsDictionary.TryGetValue(_requireMaterials[i].data, out InventoryItem stashValue))//检查玩家材料列表
{
if(stashValue.stackSize < _requireMaterials[i].stackSize)
{
Debug.Log("Not enough Materials");
return false;
}
else//如果有足够的材料
{
MaterialToRemove.Add(_requireMaterials[i]);//添加到删除列表
}
}
else
{
Debug.Log("Not enough Materials");
return false;
}

}

for(int i=0;i<MaterialToRemove.Count;i++)//删除
{
if (stashItemsDictionary.TryGetValue(MaterialToRemove[i].data, out InventoryItem value))
{
value.stackSize -= MaterialToRemove[i].stackSize;

if (value.stackSize < 1)
{
stash.Remove(value);
stashItemsDictionary.Remove(MaterialToRemove[i].data);
}
}

}
UpdataSlotUI();

AddItem(_itemToCraft);//将合成的装备添加到装备列表
Debug.Log("here is" + _itemToCraft.ItemName);
return true;
}

创建UI_craftSlot脚本:

private void OnEnable()
{
UpdataSlot(Item);//更新
}

public override void OnPointerDown(PointerEventData eventData)
{
if (Item == null)
{
return;
}
if (eventData.pointerCurrentRaycast.gameObject == gameObject)
{
ItemData_Equipment craftData = Item.data as ItemData_Equipment;

Inventory.instance.canCraft(craftData, craftData.craftingMaterials);//调用合成
}
}

2.实现敌人掉落指定物品

为物品添加一个子对象名为触发器,它专门负责拾取

为物品本身添加2D刚体,我们希望物品掉落时有随机速度

添加Item层级确保人物不会和物品碰撞

制作为预制体

ItemObject脚本:

[SerializeField] private Rigidbody2D rb;

**[SerializeField] private Vector2 velocity;

SerializeField\] private ItemData itemData;** **private void SetupVisuals() { if (itemData == null) return; GetComponent\().sprite = itemData.icon;** **gameObject.name = "Item Object -" + itemData.ItemName; }** **public void SetupItem(ItemData _itemData,Vector2 velocity)//设置物品数据和速度 { itemData = _itemData; rb.velocity = velocity;** **SetupVisuals(); } public void PickupObject()//拾取函数 { Inventory.instance.AddItem(itemData); Destroy(gameObject); }** ### 创建ItemObject_Trigger脚本: **private ItemObject myItemObject =\>GetComponentInParent\();//获取物品脚本** **private void OnTriggerEnter2D(Collider2D collision) { if (collision.GetComponent\() != null) { myItemObject.PickupObject();//实现拾取 } }** ### 创建ItemDrop脚本挂载在敌人上: **\[SerializeField\] private GameObject dropprefeb; \[SerializeField\] private ItemData item;//数据** **public void DropItem() { GameObject newDrop =Instantiate(dropprefeb,transform.position,Quaternion.identity);** **Vector2 randomVelocity = new Vector2(Random.Range(-5, 5), Random.Range(15, 20));//设置随机速度** **newDrop.GetComponent\().SetupItem(item, randomVelocity);** **}** ### EnemyStats脚本: **private ItemDrop myDropSystem;//获取掉落系统** **{ ApplyLevelModifier(); base.Start();** **enemy = GetComponent\(); myDropSystem = GetComponent\(); }** **protected override void Die()//死亡时触发掉落函数 { base.Die();** **enemy.Die();** **myDropSystem.DropItem(); }** ## 3.实现敌人的随机掉落 ### ItemData脚本: **\[Range(0, 100)

public float dropChance;//添加掉落几率**

ItemDrop脚本:

**[SerializeField] private int possibleItemDrop;//掉落的数量

SerializeField\] private ItemData\[\] possibleDrop;//可能掉落的物品 private List\ dropList =new List\();//实际上掉落物品的列表** **public void GenerateDrop()//生成掉落 { for(int i = 0; i \< possibleDrop.Length; i++)//从可能掉落的物品中筛选 { if (Random.Range(0, 100) \< possibleDrop\[i\].dropChance) { dropList.Add(possibleDrop\[i\]);//加入到掉落列表 } }** **for(int i = 0;i \< dropList.Count; i++) { ItemData newItem = dropList\[Random.Range(0, dropList.Count - i)\];//随机掉落 dropList.Remove(newItem);** **DropItem(newItem);//生成物品 } }** **public void DropItem(ItemData _item)//修改传入参数 { GameObject newDrop = Instantiate(dropprefeb, transform.position, Quaternion.identity);** **Vector2 randomVelocity = new Vector2(Random.Range(-5, 5), Random.Range(15, 20));** **newDrop.GetComponent\().SetupItem(_item, randomVelocity);** **}** ### EnemyStats脚本: **protected override void Die() { base.Die();** **enemy.Die();** **myDropSystem.GenerateDrop();//死亡调用 }**

相关推荐
charlie1145141917 小时前
精读C++20设计模式——结构型设计模式:享元模式
c++·笔记·学习·设计模式·享元模式·c++20
EQ-雪梨蛋花汤7 小时前
【Unity笔记】Unity XR 模式下 Point Light 不生效的原因与解决方法
笔记·unity·xr
开心-开心急了7 小时前
PySide6 打印(QPrinter)文本编辑器(QPlaintextEdit)内容
python·ui·pyqt
qianmo20217 小时前
基于deepseek学习三角函数相关
学习·算法
希望PZM7 小时前
Unity实现UV的中心缩放
unity·游戏引擎·uv
梦终剧8 小时前
【Android之路】UI消息循环机制
android·ui
神洛华8 小时前
YDWE编辑器系列教程三:触发编辑器
游戏·编辑器
会一点设计9 小时前
怎么使用AI在线识别字体?更好用的AI字体识别工具推荐
人工智能·ui·ux
序属秋秋秋9 小时前
《C++进阶之C++11》【lambda表达式 + 包装器】
c++·笔记·学习·c++11·lambda表达式·包装器
Hello_Embed9 小时前
STM32 智能垃圾桶项目笔记(四):PWM 回顾与舵机(SG90)控制实现
笔记·stm32·单片机·学习·嵌入式软件