统一属性计算函数

This commit is contained in:
2025-07-30 00:19:46 +08:00
parent 11a957b08a
commit 6c6fb64ab1
2 changed files with 49 additions and 31 deletions

View File

@@ -97,10 +97,11 @@ export class HeroConComp extends CCComp {
switch(data.buffType){
case BuffAttr.ATK:
this.heroView.TALENT[BuffAttr.ATK]+=data.value
this.heroView.count_ap()
this.heroView.count_atrr(BuffAttr.ATK)
break
case BuffAttr.ATK_CD:
this.heroView.TALENT[BuffAttr.ATK_CD]+=data.value
this.heroView.count_atrr(BuffAttr.ATK_CD)
break
case BuffAttr.HP:
this.heroView.TALENT[BuffAttr.HP]+=data.value

View File

@@ -236,37 +236,55 @@ export class HeroViewComp extends CCComp {
*/
add_def(def: number){
this.def+=def
if(this.is_master) this.BUFFCOMP.vmdata_update()
this.count_atrr(BuffAttr.DEF)
// this.BUFFCOMP.tooltip(TooltipTypes.defup,def.toFixed(0));
}
check_atrr(buff:BuffAttr){
switch(buff){
case BuffAttr.ATK:
return Math.floor(this.ap_base*(100+this.buff_ap+this.TALENT[BuffAttr.ATK])/100)
case BuffAttr.ATK_CD:
return this.cd/((this.buff_cd+this.TALENT[BuffAttr.ATK_CD])/100+1)
case BuffAttr.HP:
return Math.floor(this.hp_base*(100+this.buff_hp+this.TALENT[BuffAttr.HP])/100)
case BuffAttr.DEF:
return this.def+this.TALENT[BuffAttr.DEF]
}
}
count_atrr(buff:BuffAttr){
switch(buff){
case BuffAttr.ATK:
this.ap=this.check_atrr(BuffAttr.ATK)
if(this.is_master) {
this.BUFFCOMP.vmdata_update();
oops.message.dispatchEvent(GameEvent.APChange,{is_master:this.is_master,fac:this.fac})
}
break
case BuffAttr.ATK_CD:
this.cd=this.check_atrr(BuffAttr.ATK_CD)
break
case BuffAttr.HP:
this.hp_max=this.check_atrr(BuffAttr.HP)
if(this.is_master) this.BUFFCOMP.vmdata_update(true)
break
case BuffAttr.DEF:
this.def=this.check_atrr(BuffAttr.DEF)
if(this.is_master) this.BUFFCOMP.vmdata_update()
break
}
}
add_speed(cd: number){
this.buff_cd+=cd
this.count_cd()
this.count_atrr(BuffAttr.ATK_CD)
// this.BUFFCOMP.tooltip(TooltipTypes.speedup,speed.toFixed(0));
}
check_cd(){
return this.cd/((this.buff_cd+this.TALENT[BuffAttr.ATK_CD])/100+1)
}
count_cd(){
this.cd=this.check_cd()
if(this.is_master) {
this.BUFFCOMP.vmdata_update();
}
}
check_ap(){
return Math.floor(this.ap_base*(100+this.buff_ap+this.TALENT[BuffAttr.ATK])/100)
}
count_ap(){
this.ap=this.check_ap()
if(this.is_master) {
this.BUFFCOMP.vmdata_update();
oops.message.dispatchEvent(GameEvent.APChange,{is_master:this.is_master,fac:this.fac})
}
}
add_ap(ap: number,is_num:boolean=true){
// console.log("[HeroViewComp]:add_ap add:",ap,this.ap)
if(is_num){
@@ -274,8 +292,8 @@ export class HeroViewComp extends CCComp {
}else{
this.buff_ap += Math.floor(ap);
}
let diff=this.check_ap()-this.ap
this.count_ap()
let diff=this.check_atrr(BuffAttr.ATK)-this.ap
this.count_atrr(BuffAttr.ATK)
// this.BUFFCOMP.tooltip(TooltipTypes.apup,diff.toFixed(0));
}
@@ -286,8 +304,8 @@ export class HeroViewComp extends CCComp {
}else{
this.buff_ap -= Math.floor(ap/100*this.ap);
}
let diff=this.check_ap()-this.ap
this.count_ap()
let diff=this.check_atrr(BuffAttr.ATK)-this.ap
this.count_atrr(BuffAttr.ATK)
}
add_hp_max(hp: number=0,is_num:boolean=false){
@@ -297,18 +315,17 @@ export class HeroViewComp extends CCComp {
}else{
this.buff_hp+=hp
}
let diff=Math.floor(this.hp_base*(100+this.buff_hp)/100)-this.hp_max
this.hp_max =Math.floor(this.hp_base*(100+this.buff_hp)/100)
let diff=this.check_atrr(BuffAttr.HP)-this.hp_max
this.count_atrr(BuffAttr.HP)
this.hp+=diff
if(this.is_master) this.BUFFCOMP.vmdata_update(true)
// this.BUFFCOMP.tooltip(TooltipTypes.hpup,diff.toFixed(0));
}
de_hp_max(hp: number=0,is_num:boolean=true){ //最大值 只存在数值添加, 比例通过buff_hp处理
//console.log("[HeroViewComp]:de_hp_max de:",hp,this.hp_max)
this.hp_base -= Math.floor(hp) ;
let diff=Math.floor(this.hp_base*(100+this.buff_hp)/100)-this.hp_max
this.hp_max =Math.floor(this.hp_base*(100+this.buff_hp)/100)
let diff=this.check_atrr(BuffAttr.HP)-this.hp_max
this.count_atrr(BuffAttr.HP)
this.hp+=diff
if(this.is_master) this.BUFFCOMP.vmdata_update(true)
}