mirror of
https://github.com/Relintai/broken_seals.git
synced 2025-01-18 14:07:17 +01:00
Actionbar now supports items aswell.
This commit is contained in:
parent
766610586f
commit
a4aecfb9cd
@ -170,14 +170,41 @@ func setup_icon() -> void:
|
||||
spell_id = spell.id
|
||||
spell_type = spell.spell_type
|
||||
has_gcd = spell.cooldown_global_cooldown_enabled
|
||||
elif (button_entry.type == ActionBarButtonEntry.ACTION_BAR_BUTTON_ENTRY_TYPE_ITEM):
|
||||
if (button_entry.item_id == 0):
|
||||
if icon_rect.texture != null:
|
||||
ThemeAtlas.unref_texture(icon_rect.texture)
|
||||
|
||||
icon_rect.texture = null
|
||||
return
|
||||
|
||||
if icon_rect.texture != null:
|
||||
ThemeAtlas.unref_texture(icon_rect.texture)
|
||||
icon_rect.texture = null
|
||||
|
||||
var item : ItemTemplate = EntityDataManager.get_item_template(button_entry.item_id)
|
||||
|
||||
if item.icon != null:
|
||||
icon_rect.texture = ThemeAtlas.add_texture(item.icon)
|
||||
# icon_rect.texture = item.icon
|
||||
|
||||
spell_id = item.use_spell.id
|
||||
spell_type = item.use_spell.spell_type
|
||||
has_gcd = item.use_spell.cooldown_global_cooldown_enabled
|
||||
|
||||
func _on_button_pressed() -> void:
|
||||
if (button_entry.type == ActionBarButtonEntry.ACTION_BAR_BUTTON_ENTRY_TYPE_SPELL):
|
||||
if button_entry.type == ActionBarButtonEntry.ACTION_BAR_BUTTON_ENTRY_TYPE_SPELL:
|
||||
if (button_entry.item_id == 0):
|
||||
return
|
||||
|
||||
player.crequest_spell_cast(button_entry.item_id)
|
||||
|
||||
elif button_entry.type == ActionBarButtonEntry.ACTION_BAR_BUTTON_ENTRY_TYPE_ITEM:
|
||||
if (button_entry.item_id == 0):
|
||||
return
|
||||
|
||||
player.crequest_use_item(button_entry.item_id)
|
||||
|
||||
func set_button_entry_data(type: int, item_id: int) -> void:
|
||||
button_entry.type = type
|
||||
button_entry.itekm_id = item_id
|
||||
@ -221,12 +248,23 @@ func can_drop_data(pos, data) -> bool:
|
||||
|
||||
|
||||
func drop_data(pos, esd) -> void:
|
||||
if (esd.type == ESDragAndDrop.ES_DRAG_AND_DROP_TYPE_SPELL):
|
||||
if esd.type == ESDragAndDrop.ES_DRAG_AND_DROP_TYPE_SPELL and button_entry.item_id == esd.item_id:
|
||||
return
|
||||
|
||||
if esd.type == ESDragAndDrop.ES_DRAG_AND_DROP_TYPE_SPELL:
|
||||
button_entry.type = ActionBarButtonEntry.ACTION_BAR_BUTTON_ENTRY_TYPE_SPELL
|
||||
elif (esd.type == ESDragAndDrop.ES_DRAG_AND_DROP_TYPE_ITEM):
|
||||
button_entry.item_id = esd.item_id
|
||||
elif esd.type == ESDragAndDrop.ES_DRAG_AND_DROP_TYPE_ITEM or esd.type == ESDragAndDrop.ES_DRAG_AND_DROP_TYPE_INVENTORY_ITEM or esd.type == ESDragAndDrop.ES_DRAG_AND_DROP_TYPE_EQUIPPED_ITEM:
|
||||
button_entry.type = ActionBarButtonEntry.ACTION_BAR_BUTTON_ENTRY_TYPE_ITEM
|
||||
|
||||
button_entry.item_id = esd.item_id
|
||||
if button_entry.item_id != esd.item_id:
|
||||
var it : ItemTemplate = EntityDataManager.get_item_template(esd.item_id)
|
||||
|
||||
if it == null or it.use_spell == null:
|
||||
button_entry.item_id = 0
|
||||
else:
|
||||
button_entry.item_id = esd.item_id
|
||||
|
||||
|
||||
setup_icon()
|
||||
|
||||
|
@ -167,7 +167,8 @@ func get_drag_data(pos: Vector2) -> Object:
|
||||
|
||||
esd.origin = self
|
||||
esd.type = ESDragAndDrop.ES_DRAG_AND_DROP_TYPE_INVENTORY_ITEM
|
||||
esd.item_id = slot_id
|
||||
esd.item_id = item.item_template.id
|
||||
esd.set_meta("slot_id", slot_id)
|
||||
|
||||
setup_icon()
|
||||
|
||||
|
@ -61,7 +61,7 @@ func drop_data(position, data):
|
||||
return
|
||||
|
||||
if dd.type == ESDragAndDrop.ES_DRAG_AND_DROP_TYPE_INVENTORY_ITEM:
|
||||
_player.crequest_equip(equip_slot, dd.item_id)
|
||||
_player.crequest_equip(equip_slot, dd.get_meta("slot_id"))
|
||||
|
||||
func can_drop_data(position, data):
|
||||
if _player == null:
|
||||
@ -88,7 +88,8 @@ func get_drag_data(position):
|
||||
|
||||
esd.origin = self
|
||||
esd.type = ESDragAndDrop.ES_DRAG_AND_DROP_TYPE_EQUIPPED_ITEM
|
||||
esd.item_id = equip_slot
|
||||
esd.item_id = _item_instance.item_template.id
|
||||
esd.set_meta("equip_slot_id", equip_slot)
|
||||
|
||||
return esd
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user