b2ChainAndCircleContact.cpp
Go to the documentation of this file.
1 /*
2 * Copyright (c) 2006-2010 Erin Catto http://www.box2d.org
3 *
4 * This software is provided 'as-is', without any express or implied
5 * warranty. In no event will the authors be held liable for any damages
6 * arising from the use of this software.
7 * Permission is granted to anyone to use this software for any purpose,
8 * including commercial applications, and to alter it and redistribute it
9 * freely, subject to the following restrictions:
10 * 1. The origin of this software must not be misrepresented; you must not
11 * claim that you wrote the original software. If you use this software
12 * in a product, an acknowledgment in the product documentation would be
13 * appreciated but is not required.
14 * 2. Altered source versions must be plainly marked as such, and must not be
15 * misrepresented as being the original software.
16 * 3. This notice may not be removed or altered from any source distribution.
17 */
18 
24 
25 #include <new>
26 
27 b2Contact* b2ChainAndCircleContact::Create(b2Fixture* fixtureA, int32 indexA, b2Fixture* fixtureB, int32 indexB, b2BlockAllocator* allocator)
28 {
29  void* mem = allocator->Allocate(sizeof(b2ChainAndCircleContact));
30  return new (mem) b2ChainAndCircleContact(fixtureA, indexA, fixtureB, indexB);
31 }
32 
34 {
35  ((b2ChainAndCircleContact*)contact)->~b2ChainAndCircleContact();
36  allocator->Free(contact, sizeof(b2ChainAndCircleContact));
37 }
38 
40 : b2Contact(fixtureA, indexA, fixtureB, indexB)
41 {
44 }
45 
47 {
49  b2EdgeShape edge;
50  chain->GetChildEdge(&edge, m_indexA);
51  b2CollideEdgeAndCircle( manifold, &edge, xfA,
53 }
b2Fixture * m_fixtureB
Definition: b2Contact.h:206
b2Shape::Type GetType() const
Definition: b2Fixture.h:238
b2Fixture * m_fixtureA
Definition: b2Contact.h:205
void Evaluate(b2Manifold *manifold, const b2Transform &xfA, const b2Transform &xfB)
Evaluate this contact with your own manifold and transforms.
static b2Contact * Create(b2Fixture *fixtureA, int32 indexA, b2Fixture *fixtureB, int32 indexB, b2BlockAllocator *allocator)
b2ChainAndCircleContact(b2Fixture *fixtureA, int32 indexA, b2Fixture *fixtureB, int32 indexB)
void Free(void *p, int32 size)
Free memory. This will use b2Free if the size is larger than b2_maxBlockSize.
void b2CollideEdgeAndCircle(b2Manifold *manifold, const b2EdgeShape *edgeA, const b2Transform &xfA, const b2CircleShape *circleB, const b2Transform &xfB)
Compute the collision manifold between an edge and a circle.
static void Destroy(b2Contact *contact, b2BlockAllocator *allocator)
A circle shape.
Definition: b2CircleShape.h:25
signed int int32
Definition: b2Settings.h:31
void * Allocate(int32 size)
Allocate memory. This will use b2Alloc if the size is larger than b2_maxBlockSize.
void GetChildEdge(b2EdgeShape *edge, int32 index) const
Get a child edge.
#define b2Assert(A)
Definition: b2Settings.h:27
int32 m_indexA
Definition: b2Contact.h:208
b2Shape * GetShape()
Definition: b2Fixture.h:243


mvsim
Author(s):
autogenerated on Fri May 7 2021 03:05:51