1
This commit is contained in:
parent
70b296e21f
commit
06c3a6cd80
@ -23,7 +23,6 @@ void Bullet::Initialize()
|
||||
{
|
||||
Entity::Initialize();
|
||||
RecalcSelfCollider();
|
||||
skill_meta = MetaMgr::Instance()->GetSkill(skill_id);
|
||||
}
|
||||
|
||||
void Bullet::Update(int delta_time)
|
||||
@ -67,7 +66,9 @@ void Bullet::OnHit(std::set<Entity*>& objects)
|
||||
master->stats.damage_amount_out += finaly_dmg;
|
||||
hum->OnHit();
|
||||
if (!hum->HasBuffEffect(BET_Invincible)) {
|
||||
// hum->OnSkillHit(skill_meta);
|
||||
if (skill_id != 0) {
|
||||
master->TriggerOneObjectBuff(hum, BTT_SkillHit);
|
||||
}
|
||||
hum->DecHP(finaly_dmg, master->entity_uniid, master->name, meta->i->id());
|
||||
}
|
||||
}
|
||||
|
@ -23,7 +23,6 @@ class Bullet : public Entity
|
||||
a8::Vec2 born_dir;
|
||||
float fly_distance = 0.0f;
|
||||
int skill_id = 0;
|
||||
MetaData::Skill* skill_meta = nullptr;
|
||||
|
||||
Bullet();
|
||||
virtual ~Bullet() override;
|
||||
|
@ -557,7 +557,7 @@ void Human::DoSkill()
|
||||
std::set<Entity*> target_list;
|
||||
skill_target_pos = hum->pos;
|
||||
SelectSkillTargets(hum->pos, target_list);
|
||||
TriggerBuff(skill_meta_, target_list, BTT_UseSkill);
|
||||
TriggerBuff(target_list, BTT_UseSkill);
|
||||
if (!skill_meta_->phases.empty() && skill_meta_->phases[0].time_offset <= 0) {
|
||||
UpdateSkill();
|
||||
}
|
||||
@ -1067,46 +1067,48 @@ int Human::GetSkillCd()
|
||||
return skill_meta_ ? skill_meta_->i->skill_cd() * 1000 : 0;
|
||||
}
|
||||
|
||||
void Human::TriggerBuff(MetaData::Skill* sender_skill_meta,
|
||||
std::set<Entity*>& target_list, BuffTriggerType_e trigger_type)
|
||||
void Human::TriggerOneObjectBuff(Entity* target, BuffTriggerType_e trigger_type)
|
||||
{
|
||||
auto itr = sender_skill_meta->trigger_type_buffs.find(trigger_type);
|
||||
if (itr != sender_skill_meta->trigger_type_buffs.end()) {
|
||||
if (target->entity_type != ET_Player) {
|
||||
return;
|
||||
}
|
||||
Human* hum = (Human*)target;
|
||||
auto itr = skill_meta_->trigger_type_buffs.find(trigger_type);
|
||||
if (itr != skill_meta_->trigger_type_buffs.end()) {
|
||||
for (MetaData::Buff* buff_meta : itr->second) {
|
||||
for (Entity* entity : target_list) {
|
||||
if (entity->entity_type != ET_Player) {
|
||||
continue;
|
||||
switch (buff_meta->i->buff_target()) {
|
||||
case kBuffTargetSelf: //自己
|
||||
{
|
||||
if (hum == this) {
|
||||
hum->AddBuff(buff_meta);
|
||||
}
|
||||
}
|
||||
Human* hum = (Human*)entity;
|
||||
switch (buff_meta->i->buff_target()) {
|
||||
case kBuffTargetSelf: //自己
|
||||
{
|
||||
if (hum == this) {
|
||||
hum->AddBuff(buff_meta);
|
||||
}
|
||||
break;
|
||||
case kBuffTargetFriendly: //友军
|
||||
{
|
||||
if (hum->team_id == team_id) {
|
||||
hum->AddBuff(buff_meta);
|
||||
}
|
||||
break;
|
||||
case kBuffTargetFriendly: //友军
|
||||
{
|
||||
if (hum->team_id == team_id) {
|
||||
hum->AddBuff(buff_meta);
|
||||
}
|
||||
}
|
||||
break;
|
||||
case kBuffTargetEnemy: //敌军
|
||||
{
|
||||
if (sender_skill_meta->i->skill_id() == 41008) {
|
||||
hum->AddBuff(buff_meta);
|
||||
} else {
|
||||
if (hum->team_id != team_id) {
|
||||
hum->AddBuff(buff_meta);
|
||||
}
|
||||
}
|
||||
}
|
||||
break;
|
||||
}
|
||||
}//end for target_list
|
||||
}//end for buff_list
|
||||
break;
|
||||
case kBuffTargetEnemy: //敌军
|
||||
{
|
||||
if (hum->team_id != team_id) {
|
||||
hum->AddBuff(buff_meta);
|
||||
}
|
||||
}
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
void Human::TriggerBuff(std::set<Entity*>& target_list, BuffTriggerType_e trigger_type)
|
||||
{
|
||||
for (Entity* entity : target_list) {
|
||||
TriggerOneObjectBuff(entity, trigger_type);
|
||||
}
|
||||
}
|
||||
|
||||
@ -1515,7 +1517,7 @@ void Human::_UpdateAssaultMove()
|
||||
}
|
||||
}
|
||||
}
|
||||
TriggerBuff(skill_meta_, target_list, BTT_SkillHit);
|
||||
TriggerBuff(target_list, BTT_SkillHit);
|
||||
room->frame_event.AddExplosion(0, pos, 2);
|
||||
room->grid_service.MoveHuman(this);
|
||||
}
|
||||
|
@ -175,8 +175,8 @@ class Human : public Entity
|
||||
int TankLv();
|
||||
int GetSkillLeftTime();
|
||||
int GetSkillCd();
|
||||
void TriggerBuff(MetaData::Skill* sender_skill_meta,
|
||||
std::set<Entity*>& target_list, BuffTriggerType_e trigger_type);
|
||||
void TriggerOneObjectBuff(Entity* target, BuffTriggerType_e trigger_type);
|
||||
void TriggerBuff(std::set<Entity*>& target_list, BuffTriggerType_e trigger_type);
|
||||
void AddBuff(MetaData::Buff* buff_meta);
|
||||
void RemoveBuffById(int buff_id);
|
||||
void RemoveBuffByEffectId(int buff_effect_id);
|
||||
|
Loading…
x
Reference in New Issue
Block a user