Interface DamageSource
-
Nested Class Summary
Modifier and TypeInterfaceDescriptionstatic interface
Utility class to make building aDamageSource
easier. -
Method Summary
Modifier and TypeMethodDescriptionstatic @NotNull DamageSource.Builder
builder
(@NotNull DamageType damageType) Create a newDamageSource.Builder
.Get theEntity
that caused the damage to occur.대미지 컨텍스트를 가져옵니다.Get theLocation
from where the damage originated.Get theDamageType
.Get theEntity
that directly caused the damage.float
Get the amount of hunger exhaustion caused by this damage.Get theLocation
from where the damage originated.boolean
크리티컬 대미지 여부를 가져옵니다.boolean
Get if this damage is indirect.boolean
눈골렘이 녹아 발생한 대미지인지 확인합니다.boolean
isPoison()
독 포션에 의한 대미지인지 확인합니다.boolean
isSweep()
검에 의한 쓸기 공격 여부를 가져옵니다.boolean
Gets if this source of damage scales with difficulty.
-
Method Details
-
getDamageContext
대미지 컨텍스트를 가져옵니다.- Returns:
- 대미지 컨텍스트
-
isCritical
boolean isCritical()크리티컬 대미지 여부를 가져옵니다.- Returns:
- 크리티컬 대미지 여부
-
isSweep
boolean isSweep()검에 의한 쓸기 공격 여부를 가져옵니다.- Returns:
- 쓸기 공격 여부
-
isMelting
boolean isMelting()눈골렘이 녹아 발생한 대미지인지 확인합니다.- Returns:
- 눈골렘이 녹아 발생한 대미지 여부
-
isPoison
boolean isPoison()독 포션에 의한 대미지인지 확인합니다.- Returns:
- 독 포션에 의한 대미지 여부
-
getDamageType
Get theDamageType
.- Returns:
- the damage type
-
getCausingEntity
Get theEntity
that caused the damage to occur.Not to be confused with
getDirectEntity()
, the causing entity is the entity to which the damage is ultimately attributed if the receiver is killed. If, for example, the receiver was damaged by a projectile, the shooter/thrower would be returned.- Returns:
- an Entity or null
-
getDirectEntity
Get theEntity
that directly caused the damage.Not to be confused with
getCausingEntity()
, the direct entity is the entity that actually inflicted the damage. If, for example, the receiver was damaged by a projectile, the projectile would be returned.- Returns:
- an Entity or null
-
getDamageLocation
Get theLocation
from where the damage originated. This will only be present if an entity did not cause the damage.- Returns:
- the location, or null if none
-
getSourceLocation
Get theLocation
from where the damage originated.This is a convenience method to get the final location of the damage. This method will attempt to return
the damage location
. If this is null, thecausing entity location
will be returned. Finally if there is no damage location nor a causing entity, null will be returned.- Returns:
- the source of the location or null.
-
isIndirect
boolean isIndirect()Get if this damage is indirect.Damage is considered indirect if
getCausingEntity()
is not equal togetDirectEntity()
. This will be the case, for example, if a skeleton shot an arrow or a player threw a potion.- Returns:
true
if is indirect,false
otherwise.
-
getFoodExhaustion
float getFoodExhaustion()Get the amount of hunger exhaustion caused by this damage.- Returns:
- the amount of hunger exhaustion caused.
-
scalesWithDifficulty
boolean scalesWithDifficulty()Gets if this source of damage scales with difficulty.- Returns:
True
if scales.
-
builder
Create a newDamageSource.Builder
.- Parameters:
damageType
- theDamageType
to use- Returns:
- a
DamageSource.Builder
-