2019-11-23 20:27:39 +08:00
|
|
|
/****************************************************************************
|
|
|
|
Copyright (C) 2013 Henry van Merode. All rights reserved.
|
|
|
|
Copyright (c) 2015-2016 Chukong Technologies Inc.
|
|
|
|
Copyright (c) 2017-2018 Xiamen Yaji Software Co., Ltd.
|
2021-12-25 10:04:45 +08:00
|
|
|
|
2022-10-01 16:24:52 +08:00
|
|
|
https://axmolengine.github.io/
|
2021-12-25 10:04:45 +08:00
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
|
|
of this software and associated documentation files (the "Software"), to deal
|
|
|
|
in the Software without restriction, including without limitation the rights
|
|
|
|
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
|
|
copies of the Software, and to permit persons to whom the Software is
|
|
|
|
furnished to do so, subject to the following conditions:
|
2021-12-25 10:04:45 +08:00
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
The above copyright notice and this permission notice shall be included in
|
|
|
|
all copies or substantial portions of the Software.
|
2021-12-25 10:04:45 +08:00
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
|
|
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
|
|
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
|
|
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
|
|
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
|
|
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
|
|
|
THE SOFTWARE.
|
|
|
|
****************************************************************************/
|
|
|
|
|
2023-06-11 13:08:08 +08:00
|
|
|
#include "PUBaseCollider.h"
|
|
|
|
#include "extensions/Particle3D/PU/PUParticleSystem3D.h"
|
2019-11-23 20:27:39 +08:00
|
|
|
|
2022-07-11 17:50:21 +08:00
|
|
|
NS_AX_BEGIN
|
2019-11-23 20:27:39 +08:00
|
|
|
|
|
|
|
// Constants
|
2021-12-25 10:04:45 +08:00
|
|
|
const float PUBaseCollider::DEFAULT_BOUNCYNESS = 1.0f;
|
|
|
|
const float PUBaseCollider::DEFAULT_FRICTION = 0.0f;
|
2019-11-23 20:27:39 +08:00
|
|
|
const PUBaseCollider::IntersectionType PUBaseCollider::DEFAULT_INTERSECTION_TYPE = PUBaseCollider::IT_POINT;
|
2021-12-25 10:04:45 +08:00
|
|
|
const PUBaseCollider::CollisionType PUBaseCollider::DEFAULT_COLLISION_TYPE = PUBaseCollider::CT_BOUNCE;
|
2019-11-23 20:27:39 +08:00
|
|
|
//-----------------------------------------------------------------------
|
2021-12-25 10:04:45 +08:00
|
|
|
PUBaseCollider::PUBaseCollider()
|
2019-11-23 20:27:39 +08:00
|
|
|
: PUAffector()
|
|
|
|
, _friction(DEFAULT_FRICTION)
|
|
|
|
, _bouncyness(DEFAULT_BOUNCYNESS)
|
|
|
|
, _intersectionType(DEFAULT_INTERSECTION_TYPE)
|
|
|
|
, _collisionType(DEFAULT_COLLISION_TYPE)
|
|
|
|
, _velocityScale(1.0f)
|
2021-12-25 10:04:45 +08:00
|
|
|
{}
|
2019-11-23 20:27:39 +08:00
|
|
|
|
2021-12-25 10:04:45 +08:00
|
|
|
PUBaseCollider::~PUBaseCollider() {}
|
2019-11-23 20:27:39 +08:00
|
|
|
|
|
|
|
PUBaseCollider::IntersectionType PUBaseCollider::getIntersectionType() const
|
|
|
|
{
|
|
|
|
return _intersectionType;
|
|
|
|
}
|
|
|
|
|
2021-12-25 10:04:45 +08:00
|
|
|
void PUBaseCollider::setIntersectionType(const IntersectionType& intersectionType)
|
2019-11-23 20:27:39 +08:00
|
|
|
{
|
|
|
|
_intersectionType = intersectionType;
|
|
|
|
}
|
|
|
|
|
|
|
|
PUBaseCollider::CollisionType PUBaseCollider::getCollisionType() const
|
|
|
|
{
|
|
|
|
return _collisionType;
|
|
|
|
}
|
|
|
|
|
2021-12-25 10:04:45 +08:00
|
|
|
void PUBaseCollider::setCollisionType(const CollisionType& collisionType)
|
2019-11-23 20:27:39 +08:00
|
|
|
{
|
|
|
|
_collisionType = collisionType;
|
|
|
|
}
|
|
|
|
|
|
|
|
float PUBaseCollider::getFriction() const
|
|
|
|
{
|
|
|
|
return _friction;
|
|
|
|
}
|
|
|
|
|
2021-12-25 10:04:45 +08:00
|
|
|
void PUBaseCollider::setFriction(const float friction)
|
2019-11-23 20:27:39 +08:00
|
|
|
{
|
|
|
|
_friction = friction;
|
|
|
|
}
|
|
|
|
|
|
|
|
float PUBaseCollider::getBouncyness() const
|
|
|
|
{
|
|
|
|
return _bouncyness;
|
|
|
|
}
|
|
|
|
|
2021-12-25 10:04:45 +08:00
|
|
|
void PUBaseCollider::setBouncyness(const float bouncyness)
|
2019-11-23 20:27:39 +08:00
|
|
|
{
|
|
|
|
_bouncyness = bouncyness;
|
|
|
|
}
|
|
|
|
|
2021-12-25 10:04:45 +08:00
|
|
|
void PUBaseCollider::populateAlignedBox(AABB& box,
|
|
|
|
const Vec3& position,
|
|
|
|
const float width,
|
|
|
|
const float height,
|
|
|
|
const float depth)
|
2019-11-23 20:27:39 +08:00
|
|
|
{
|
2021-12-25 10:04:45 +08:00
|
|
|
float halfWidth = 0.5f * width;
|
2019-11-23 20:27:39 +08:00
|
|
|
float halfHeight = 0.5f * height;
|
2021-12-25 10:04:45 +08:00
|
|
|
float halfDepth = 0.5f * depth;
|
|
|
|
box.set(Vec3(position.x - halfWidth, position.y - halfHeight, position.z - halfDepth),
|
|
|
|
Vec3(position.x + halfWidth, position.y + halfHeight, position.z + halfDepth));
|
2019-11-23 20:27:39 +08:00
|
|
|
}
|
|
|
|
|
2021-12-25 10:04:45 +08:00
|
|
|
void PUBaseCollider::calculateRotationSpeedAfterCollision(PUParticle3D* particle)
|
2019-11-23 20:27:39 +08:00
|
|
|
{
|
|
|
|
if (particle->particleType != PUParticle3D::PT_VISUAL)
|
|
|
|
return;
|
|
|
|
|
2022-07-16 10:43:05 +08:00
|
|
|
float signedFriction = AXRANDOM_0_1() > 0.5f ? -(_friction - 1) : (_friction - 1);
|
2019-11-23 20:27:39 +08:00
|
|
|
|
|
|
|
particle->rotationSpeed *= signedFriction;
|
|
|
|
particle->zRotationSpeed *= signedFriction;
|
|
|
|
}
|
|
|
|
|
2021-12-25 10:04:45 +08:00
|
|
|
void PUBaseCollider::preUpdateAffector(float deltaTime)
|
2019-11-23 20:27:39 +08:00
|
|
|
{
|
|
|
|
// Take scaled velocity into account
|
2021-12-25 10:04:45 +08:00
|
|
|
_velocityScale = deltaTime * (static_cast<PUParticleSystem3D*>(_particleSystem))->getParticleSystemScaleVelocity();
|
2019-11-23 20:27:39 +08:00
|
|
|
}
|
|
|
|
|
2021-12-25 10:04:45 +08:00
|
|
|
void PUBaseCollider::copyAttributesTo(PUAffector* affector)
|
2019-11-23 20:27:39 +08:00
|
|
|
{
|
|
|
|
PUAffector::copyAttributesTo(affector);
|
|
|
|
|
2021-12-25 10:04:45 +08:00
|
|
|
PUBaseCollider* baseCollider = static_cast<PUBaseCollider*>(affector);
|
|
|
|
baseCollider->_bouncyness = _bouncyness;
|
|
|
|
baseCollider->_friction = _friction;
|
2019-11-23 20:27:39 +08:00
|
|
|
baseCollider->_intersectionType = _intersectionType;
|
2021-12-25 10:04:45 +08:00
|
|
|
baseCollider->_collisionType = _collisionType;
|
2019-11-23 20:27:39 +08:00
|
|
|
}
|
|
|
|
|
2022-07-11 17:50:21 +08:00
|
|
|
NS_AX_END
|