1
This commit is contained in:
parent
ed9a61017a
commit
0d380ca7e7
@ -23,9 +23,6 @@ HeroAgent::~HeroAgent()
|
|||||||
|
|
||||||
State_e HeroAgent::GetState()
|
State_e HeroAgent::GetState()
|
||||||
{
|
{
|
||||||
#ifdef DEBUG1
|
|
||||||
a8::XPrintf("GetState\n", {});
|
|
||||||
#endif
|
|
||||||
return kPreBattle;
|
return kPreBattle;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -35,53 +32,57 @@ behaviac::EBTStatus HeroAgent::DoIdle(int min_time, int max_time)
|
|||||||
return DoRunningCb();
|
return DoRunningCb();
|
||||||
}
|
}
|
||||||
|
|
||||||
int idle_time = a8::RandEx(min_time, max_time);
|
auto context = A8_MAKE_ANON_STRUCT_SHARED
|
||||||
a8::XTimerWp timer_ptr = GetOwner()->room->xtimer.SetTimeoutWpEx
|
|
||||||
(
|
(
|
||||||
idle_time / FRAME_RATE_MS,
|
a8::XTimerWp timer_ptr;
|
||||||
|
CreatureWeakPtr last_attacker;
|
||||||
|
long long last_attacked_frameno = 0;
|
||||||
|
std::weak_ptr<EventHandlerPtr> handler;
|
||||||
|
);
|
||||||
|
context->timer_ptr = GetOwner()->room->xtimer.SetTimeoutWpEx
|
||||||
|
(
|
||||||
|
a8::RandEx(min_time, max_time) / FRAME_RATE_MS,
|
||||||
[] (int event, const a8::Args* args)
|
[] (int event, const a8::Args* args)
|
||||||
{
|
{
|
||||||
},
|
},
|
||||||
&GetOwner()->xtimer_attacher);
|
&GetOwner()->xtimer_attacher);
|
||||||
|
context->handler = GetOwner()->GetTrigger()->AddListener
|
||||||
std::shared_ptr<CreatureWeakPtr> last_attacker = std::make_shared<CreatureWeakPtr>();
|
|
||||||
std::shared_ptr<long long> last_attacked_frameno = std::make_shared<long long>(0);
|
|
||||||
std::weak_ptr<EventHandlerPtr> handler = GetOwner()->GetTrigger()->AddListener
|
|
||||||
(
|
(
|
||||||
kAttacked,
|
kAttacked,
|
||||||
[this, last_attacker, last_attacked_frameno] (const a8::Args& args)
|
[this, context] (const a8::Args& args)
|
||||||
{
|
{
|
||||||
Creature* c = args.Get<Creature*>(0);
|
Creature* c = args.Get<Creature*>(0);
|
||||||
*last_attacker = c->GetWeakPtrRef();
|
context->last_attacker = c->GetWeakPtrRef();
|
||||||
*last_attacked_frameno = c->room->GetFrameNo();
|
context->last_attacked_frameno = c->room->GetFrameNo();
|
||||||
|
});
|
||||||
|
auto holder = std::make_shared<a8::Holder>
|
||||||
|
(
|
||||||
|
[context] (const a8::Args& args)
|
||||||
|
{
|
||||||
|
/*
|
||||||
|
if (!handler.expired()) {
|
||||||
|
GetOwner()->GetTrigger()->RemoveEventHandler(handler);
|
||||||
|
}*/
|
||||||
});
|
});
|
||||||
|
|
||||||
return StartCoroutine
|
return StartCoroutine
|
||||||
(
|
(
|
||||||
[this, timer_ptr, handler] ()
|
[this, context, holder] ()
|
||||||
{
|
{
|
||||||
if (!timer_ptr.expired()) {
|
if (!context->timer_ptr.expired()) {
|
||||||
return behaviac::BT_RUNNING;
|
return behaviac::BT_RUNNING;
|
||||||
} else {
|
} else {
|
||||||
if (!handler.expired()) {
|
|
||||||
GetOwner()->GetTrigger()->RemoveEventHandler(handler);
|
|
||||||
}
|
|
||||||
return behaviac::BT_SUCCESS;
|
return behaviac::BT_SUCCESS;
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
[this, timer_ptr, handler, last_attacker, last_attacked_frameno]
|
[this, context, holder]
|
||||||
(bool is_test, bool& has_event) mutable
|
(bool is_test, bool& has_event) mutable
|
||||||
{
|
{
|
||||||
has_event = last_attacker->Get() && !last_attacker->Get()->dead ? true : false;
|
has_event = context->last_attacker.Get() && !context->last_attacker.Get()->dead ? true : false;
|
||||||
if (!is_test && has_event) {
|
if (!is_test && has_event) {
|
||||||
if (!timer_ptr.expired()) {
|
FireEvent("OnAttacked",
|
||||||
GetOwner()->room->xtimer.Delete(timer_ptr);
|
context->last_attacker.Get()->GetUniId(),
|
||||||
}
|
context->last_attacked_frameno);
|
||||||
if (!handler.expired()) {
|
|
||||||
GetOwner()->GetTrigger()->RemoveEventHandler(handler);
|
|
||||||
|
|
||||||
}
|
|
||||||
FireEvent("OnAttacked", last_attacker->Get()->GetUniId(), *last_attacked_frameno);
|
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"CoIdle"
|
"CoIdle"
|
||||||
|
Loading…
x
Reference in New Issue
Block a user