mirror of
https://github.com/GreenComfyTea/MHR-Overlay.git
synced 2026-01-24 12:28:03 -08:00
Functions and fields are cached, part names added, part name language support added.
This commit is contained in:
@@ -2,11 +2,21 @@ local damage_hook = {};
|
||||
local quest_status;
|
||||
local player;
|
||||
|
||||
|
||||
|
||||
local enemy_character_base_type_def = sdk.find_type_definition("snow.enemy.EnemyCharacterBase");
|
||||
local enemy_character_base_after_calc_damage_damage_side = enemy_character_base_type_def:get_method("afterCalcDamage_DamageSide");
|
||||
|
||||
local is_boss_enemy_method = enemy_character_base_type_def:get_method("get_isBossEnemy");
|
||||
local check_die_method = enemy_character_base_type_def:get_method("checkDie");
|
||||
|
||||
local enemy_calc_damage_info_type_def = sdk.find_type_definition("snow.hit.EnemyCalcDamageInfo.AfterCalcInfo_DamageSide");
|
||||
local get_attacker_id_method = enemy_calc_damage_info_type_def:get_method("get_AttackerID");
|
||||
local get_damage_attacker_type_method = enemy_calc_damage_info_type_def:get_method("get_DamageAttackerType");
|
||||
|
||||
local get_total_damage_method = enemy_calc_damage_info_type_def:get_method("get_TotalDamage");
|
||||
local get_physical_damage_method = enemy_calc_damage_info_type_def:get_method("get_PhysicalDamage");
|
||||
local get_elemental_damage_method = enemy_calc_damage_info_type_def:get_method("get_ElementDamage");
|
||||
local get_condition_damage_method = enemy_calc_damage_info_type_def:get_method("get_ConditionDamage");
|
||||
|
||||
sdk.hook(enemy_character_base_after_calc_damage_damage_side, function(args)
|
||||
damage_hook.update_damage(args);
|
||||
end, function(retval)
|
||||
@@ -19,12 +29,13 @@ function damage_hook.update_damage(args)
|
||||
return;
|
||||
end
|
||||
|
||||
local is_large_monster = enemy:call("get_isBossEnemy");
|
||||
local is_large_monster = is_boss_enemy_method:call(enemy);
|
||||
|
||||
if is_large_monster == nil then
|
||||
return;
|
||||
end
|
||||
|
||||
local dead_or_captured = enemy:call("checkDie");
|
||||
local dead_or_captured = check_die_method:call(enemy);
|
||||
if dead_or_captured == nil then
|
||||
return;
|
||||
end
|
||||
@@ -34,8 +45,8 @@ function damage_hook.update_damage(args)
|
||||
end
|
||||
|
||||
local enemy_calc_damage_info = sdk.to_managed_object(args[3]); -- snow.hit.EnemyCalcDamageInfo.AfterCalcInfo_DamageSide
|
||||
local attacker_id = enemy_calc_damage_info:call("get_AttackerID");
|
||||
local attacker_type = enemy_calc_damage_info:call("get_DamageAttackerType");
|
||||
local attacker_id = get_attacker_id_method:call(enemy_calc_damage_info);
|
||||
local attacker_type = get_damage_attacker_type_method:call(enemy_calc_damage_info);
|
||||
|
||||
if attacker_id >= 100 then
|
||||
return;
|
||||
@@ -47,10 +58,10 @@ function damage_hook.update_damage(args)
|
||||
end
|
||||
|
||||
local damage_object = {}
|
||||
damage_object.total_damage = enemy_calc_damage_info:call("get_TotalDamage");
|
||||
damage_object.physical_damage = enemy_calc_damage_info:call("get_PhysicalDamage");
|
||||
damage_object.elemental_damage = enemy_calc_damage_info:call("get_ElementDamage");
|
||||
damage_object.ailment_damage = enemy_calc_damage_info:call("get_ConditionDamage");
|
||||
damage_object.total_damage = get_total_damage_method:call(enemy_calc_damage_info);
|
||||
damage_object.physical_damage = get_physical_damage_method:call(enemy_calc_damage_info);
|
||||
damage_object.elemental_damage = get_elemental_damage_method:call(enemy_calc_damage_info);
|
||||
damage_object.ailment_damage = get_condition_damage_method:call(enemy_calc_damage_info);
|
||||
|
||||
-- -1 - bombs
|
||||
-- 0 - player
|
||||
|
||||
Reference in New Issue
Block a user