diff --git a/CHANGELOG.md b/CHANGELOG.md index 1d6d581b7..34c08a428 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -2,6 +2,7 @@ - push improvements. - `Movement` mixin improvements. - Other otimizations +- Fix intermittent crash after `simpleAttackRanged` is called # 3.9.2 - MiniMap improviments. Fix issue [#517](https://github.com/RafaelBarbosatec/bonfire/issues/517) diff --git a/lib/collision/block_movement_collision.dart b/lib/collision/block_movement_collision.dart index 74d28461f..05359ed34 100644 --- a/lib/collision/block_movement_collision.dart +++ b/lib/collision/block_movement_collision.dart @@ -75,8 +75,10 @@ mixin BlockMovementCollision on Movement { @override void onCollision(Set intersectionPoints, PositionComponent other) { - super.onCollision(intersectionPoints, other); - if (other is Sensor || !_blockMovementCollisionEnabled) return; + if (other is Sensor || !_blockMovementCollisionEnabled) { + super.onCollision(intersectionPoints, other); + return; + } bool stopOtherMovement = true; bool stopMovement = other is GameComponent ? onBlockMovement(intersectionPoints, other) @@ -89,6 +91,7 @@ mixin BlockMovementCollision on Movement { } if (!stopMovement || !stopOtherMovement) { + super.onCollision(intersectionPoints, other); return; } @@ -98,18 +101,24 @@ mixin BlockMovementCollision on Movement { _collisionsResolution[other]!, ); _collisionsResolution.remove(other); + super.onCollision(intersectionPoints, other); return; } - ShapeHitbox shape1 = _getCollisionShapeHitbox( + ShapeHitbox? shape1 = _getCollisionShapeHitbox( shapeHitboxes, intersectionPoints, ); - ShapeHitbox shape2 = _getCollisionShapeHitbox( + ShapeHitbox? shape2 = _getCollisionShapeHitbox( other.children.query(), intersectionPoints, ); + if (shape1 == null || shape2 == null) { + super.onCollision(intersectionPoints, other); + return; + } + ({Vector2 normal, double depth})? colisionResult; if (_isPolygon(shape1)) { @@ -143,6 +152,7 @@ mixin BlockMovementCollision on Movement { other.setCollisionResolution(this, data.inverted()); } } + super.onCollision(intersectionPoints, other); } bool _isPolygon(ShapeHitbox shape) { @@ -273,10 +283,11 @@ mixin BlockMovementCollision on Movement { return (normal: normal, depth: depth); } - ShapeHitbox _getCollisionShapeHitbox( + ShapeHitbox? _getCollisionShapeHitbox( List shapeHitboxes, Set intersectionPoints, ) { + if (shapeHitboxes.isEmpty || intersectionPoints.isEmpty) return null; if (shapeHitboxes.length == 1) { return shapeHitboxes.first; } diff --git a/lib/mixins/direction_animation.dart b/lib/mixins/direction_animation.dart index 046b5cac2..e9cf54916 100644 --- a/lib/mixins/direction_animation.dart +++ b/lib/mixins/direction_animation.dart @@ -91,9 +91,9 @@ mixin DirectionAnimation on Movement { await animation?.onLoad(gameRef); return super.onLoad(); } - + @override - void onMount(){ + void onMount() { super.onMount(); idle(); }