1
This commit is contained in:
parent
0c8156ba69
commit
9166c94882
@ -277,7 +277,7 @@ enum PropertyType_e
|
|||||||
{
|
{
|
||||||
kPropHp = 1,
|
kPropHp = 1,
|
||||||
kPropMaxHp = 2,
|
kPropMaxHp = 2,
|
||||||
kPropSkillLeftTime = 4,
|
kPropSkillLeftTime_ = 4,
|
||||||
kPropSkillCd = 5,
|
kPropSkillCd = 5,
|
||||||
kPropTankBulletNum = 6,
|
kPropTankBulletNum = 6,
|
||||||
kPropTankOil = 7,
|
kPropTankOil = 7,
|
||||||
@ -287,7 +287,7 @@ enum PropertyType_e
|
|||||||
kPropCar = 11,
|
kPropCar = 11,
|
||||||
|
|
||||||
kPropZombieId = 23,
|
kPropZombieId = 23,
|
||||||
kPropSkillLefTime = 24,
|
kPropSkillLeftTime = 24,
|
||||||
};
|
};
|
||||||
|
|
||||||
enum MapObjectType_e
|
enum MapObjectType_e
|
||||||
|
@ -281,6 +281,15 @@ void Creature::FillBuffList(::google::protobuf::RepeatedPtrField<::cs::MFBuff>*
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void Creature::FillSkillList(::google::protobuf::RepeatedPtrField< cs::MFSkill >*
|
||||||
|
pb_skill_list)
|
||||||
|
{
|
||||||
|
for (auto& pair : skill_hash_) {
|
||||||
|
auto skill = pb_skill_list->Add();
|
||||||
|
pair.second->FillMFSkill(skill);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void Creature::AddPassiveSkill(int skill_id)
|
void Creature::AddPassiveSkill(int skill_id)
|
||||||
{
|
{
|
||||||
MetaData::Skill* skill_meta = MetaMgr::Instance()->GetSkill(skill_id);
|
MetaData::Skill* skill_meta = MetaMgr::Instance()->GetSkill(skill_id);
|
||||||
|
@ -48,6 +48,7 @@ class Creature : public MoveableEntity
|
|||||||
float GetBuffAttrAbs(int attr_id);
|
float GetBuffAttrAbs(int attr_id);
|
||||||
float GetBuffAttrRate(int attr_id);
|
float GetBuffAttrRate(int attr_id);
|
||||||
void FillBuffList(::google::protobuf::RepeatedPtrField<::cs::MFBuff>* pb_buff_list);
|
void FillBuffList(::google::protobuf::RepeatedPtrField<::cs::MFBuff>* pb_buff_list);
|
||||||
|
void FillSkillList(::google::protobuf::RepeatedPtrField< cs::MFSkill >* pb_skill_list);
|
||||||
void TriggerBuff(Skill* skill, std::set<Entity*>& target_list, BuffTriggerType_e trigger_type);
|
void TriggerBuff(Skill* skill, std::set<Entity*>& target_list, BuffTriggerType_e trigger_type);
|
||||||
Skill* GetSkill(int skill_id);
|
Skill* GetSkill(int skill_id);
|
||||||
void AddSkill(int skill_id);
|
void AddSkill(int skill_id);
|
||||||
|
@ -238,11 +238,16 @@ void FrameEvent::RemoveBuff(Human* sender, int buff_id)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void FrameEvent::AddSkillCdChg(Human* hum)
|
void FrameEvent::AddSkillCdChg(Human* sender, int skill_id, int left_time)
|
||||||
{
|
{
|
||||||
chged_skillcds_.push_back(hum);
|
chged_skillcds_.push_back(std::make_tuple(sender, skill_id, left_time));
|
||||||
int idx = chged_skillcds_.size() - 1;
|
int idx = chged_skillcds_.size() - 1;
|
||||||
|
sender->TouchAllLayerHumanList
|
||||||
|
(
|
||||||
|
[idx] (Human* hum, bool& stop)
|
||||||
|
{
|
||||||
hum->chged_skillcds_.push_back(idx);
|
hum->chged_skillcds_.push_back(idx);
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
void FrameEvent::AddItemChg(Human* hum, int item_id, int item_num)
|
void FrameEvent::AddItemChg(Human* hum, int item_id, int item_num)
|
||||||
|
@ -27,7 +27,7 @@ public:
|
|||||||
void AddWeaponAmmoChg(Human* hum);
|
void AddWeaponAmmoChg(Human* hum);
|
||||||
void AddBuff(Human* hum, Buff* buff);
|
void AddBuff(Human* hum, Buff* buff);
|
||||||
void RemoveBuff(Human* hum, int buff_id);
|
void RemoveBuff(Human* hum, int buff_id);
|
||||||
void AddSkillCdChg(Human* hum);
|
void AddSkillCdChg(Human* hum, int skill_id, int left_time);
|
||||||
void AddItemChg(Human* hum, int item_id, int item_num);
|
void AddItemChg(Human* hum, int item_id, int item_num);
|
||||||
void AddZombieIdChg(Human* hum);
|
void AddZombieIdChg(Human* hum);
|
||||||
void AddDead(Human* sender, int revive_time);
|
void AddDead(Human* sender, int revive_time);
|
||||||
@ -47,7 +47,7 @@ private:
|
|||||||
std::vector<Human*> chged_bullet_nums_;
|
std::vector<Human*> chged_bullet_nums_;
|
||||||
std::vector<std::tuple<Human*, int, int>> chged_weapon_ammo_;
|
std::vector<std::tuple<Human*, int, int>> chged_weapon_ammo_;
|
||||||
std::vector<Human*> chged_hps_;
|
std::vector<Human*> chged_hps_;
|
||||||
std::vector<Human*> chged_skillcds_;
|
std::vector<std::tuple<Human*, int, int>> chged_skillcds_;
|
||||||
std::vector<Human*> chged_zombieids_;
|
std::vector<Human*> chged_zombieids_;
|
||||||
std::vector<Human*> chged_cars_;
|
std::vector<Human*> chged_cars_;
|
||||||
std::vector<std::tuple<int, int, int>> dead_alive_objs_;
|
std::vector<std::tuple<int, int, int>> dead_alive_objs_;
|
||||||
|
@ -149,25 +149,21 @@ cs::SMUpdate* FrameMaker::MakeUpdateMsg(const Human* hum)
|
|||||||
*p = std::get<1>(room->frame_event.chged_buffs_[idx]);
|
*p = std::get<1>(room->frame_event.chged_buffs_[idx]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#if 0
|
|
||||||
for (size_t idx : hum->chged_skillcds_) {
|
for (size_t idx : hum->chged_skillcds_) {
|
||||||
if (idx < room->frame_event.chged_skillcds_.size()) {
|
if (idx < room->frame_event.chged_skillcds_.size()) {
|
||||||
Human* target = room->frame_event.chged_skillcds_[idx];
|
auto tuple = room->frame_event.chged_skillcds_[idx];
|
||||||
|
Human* target = std::get<0>(tuple);
|
||||||
|
int skill_id = std::get<1>(tuple);
|
||||||
|
int left_time = std::get<2>(tuple);
|
||||||
{
|
{
|
||||||
auto p = msg->add_chged_property_list();
|
auto p = msg->add_chged_property_list();
|
||||||
p->set_obj_id(target->GetEntityUniId());
|
p->set_obj_id(target->GetEntityUniId());
|
||||||
p->set_property_type(kPropSkillLeftTime);
|
p->set_property_type(kPropSkillLeftTime);
|
||||||
p->set_value(target->GetSkillLeftTime());
|
p->set_property_subtype(skill_id);
|
||||||
}
|
p->set_value(left_time);
|
||||||
{
|
|
||||||
auto p = msg->add_chged_property_list();
|
|
||||||
p->set_obj_id(target->GetEntityUniId());
|
|
||||||
p->set_property_type(kPropSkillCd);
|
|
||||||
p->set_value(target->GetSkillCd());
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
for (size_t idx : hum->chged_hps_) {
|
for (size_t idx : hum->chged_hps_) {
|
||||||
if (idx < room->frame_event.chged_hps_.size()) {
|
if (idx < room->frame_event.chged_hps_.size()) {
|
||||||
Human* target = room->frame_event.chged_hps_[idx];
|
Human* target = room->frame_event.chged_hps_[idx];
|
||||||
|
@ -217,6 +217,7 @@ void Human::FillMFObjectFull(Room* room, Human* hum, cs::MFObjectFull* full_data
|
|||||||
}
|
}
|
||||||
FillBodyState(p->mutable_states());
|
FillBodyState(p->mutable_states());
|
||||||
FillBuffList(p->mutable_buff_list());
|
FillBuffList(p->mutable_buff_list());
|
||||||
|
FillSkillList(p->mutable_skill_list());
|
||||||
if (dead) {
|
if (dead) {
|
||||||
p->set_killer_name(stats.killer_name);
|
p->set_killer_name(stats.killer_name);
|
||||||
p->set_killer_id(stats.killer_id);
|
p->set_killer_id(stats.killer_id);
|
||||||
@ -1486,6 +1487,7 @@ void Human::FillMFActivePlayerData(cs::MFActivePlayerData* player_data)
|
|||||||
#endif
|
#endif
|
||||||
FillBodyState(player_data->mutable_states());
|
FillBodyState(player_data->mutable_states());
|
||||||
FillItemList(player_data->mutable_items());
|
FillItemList(player_data->mutable_items());
|
||||||
|
FillSkillList(player_data->mutable_skill_list());
|
||||||
}
|
}
|
||||||
|
|
||||||
void Human::FillMFGasData(cs::MFGasData* gas_data)
|
void Human::FillMFGasData(cs::MFGasData* gas_data)
|
||||||
@ -3512,9 +3514,10 @@ void Human::DoSkillPostProc(bool used, int skill_id, int target_id, const a8::Ve
|
|||||||
{
|
{
|
||||||
if (used) {
|
if (used) {
|
||||||
++stats.skill_times;
|
++stats.skill_times;
|
||||||
#if 0
|
Skill* skill = GetSkill(skill_id);
|
||||||
room->frame_event.AddSkillCdChg(this);
|
if (skill) {
|
||||||
#endif
|
room->frame_event.AddSkillCdChg(this, skill_id, skill->GetLeftTime());
|
||||||
|
}
|
||||||
OnAttack();
|
OnAttack();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -23,6 +23,13 @@ int Skill::GetLeftTime()
|
|||||||
return skill_left_time;
|
return skill_left_time;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void Skill::FillMFSkill(cs::MFSkill* skill_pb)
|
||||||
|
{
|
||||||
|
skill_pb->set_skill_id(meta->i->skill_id());
|
||||||
|
skill_pb->set_left_time(GetLeftTime());
|
||||||
|
skill_pb->set_cd_time(GetCd());
|
||||||
|
}
|
||||||
|
|
||||||
void Skill::ClearPassiveSkillBuff()
|
void Skill::ClearPassiveSkillBuff()
|
||||||
{
|
{
|
||||||
for (int buff_id : meta->buff_list) {
|
for (int buff_id : meta->buff_list) {
|
||||||
|
@ -5,6 +5,11 @@ namespace MetaData
|
|||||||
struct Skill;
|
struct Skill;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
namespace cs
|
||||||
|
{
|
||||||
|
class MFSkill;
|
||||||
|
}
|
||||||
|
|
||||||
class Creature;
|
class Creature;
|
||||||
class Skill
|
class Skill
|
||||||
{
|
{
|
||||||
@ -17,6 +22,7 @@ class Skill
|
|||||||
int GetCd();
|
int GetCd();
|
||||||
int GetLeftTime();
|
int GetLeftTime();
|
||||||
int GetPassedTime();
|
int GetPassedTime();
|
||||||
|
void FillMFSkill(cs::MFSkill* skill_pb);
|
||||||
|
|
||||||
void ClearPassiveSkillBuff();
|
void ClearPassiveSkillBuff();
|
||||||
void AddPassiveSkillBuff();
|
void AddPassiveSkillBuff();
|
||||||
|
Loading…
x
Reference in New Issue
Block a user