All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.badlogic.gdx.physics.box2d.Fixture Maven / Gradle / Ivy

/*******************************************************************************
 * Copyright 2011 See AUTHORS file.
 * 
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 * 
 *   http://www.apache.org/licenses/LICENSE-2.0
 * 
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 ******************************************************************************/

package com.badlogic.gdx.physics.box2d;

import org.jbox2d.collision.shapes.ShapeType;
import org.jbox2d.common.Vec2;

import com.badlogic.gdx.math.Vector2;
import com.badlogic.gdx.physics.box2d.Shape.Type;

public class Fixture {
	org.jbox2d.dynamics.Fixture fixture;
	private Body body;
	protected Shape shape;
	protected Object userData;

	/** Constructs a new fixture
	 * @param addr the address of the fixture */
	protected Fixture (Body body, org.jbox2d.dynamics.Fixture fixture) {
		this.body = body;
		this.fixture = fixture;
	}

	protected void reset (Body body, org.jbox2d.dynamics.Fixture fixture) {
		this.body = body;
		this.fixture = fixture;
		this.shape = null;
		this.userData = null;
	}

	/** Get the type of the child shape. You can use this to down cast to the concrete shape.
	 * @return the shape type. */
	public Type getType () {
		ShapeType type = fixture.getType();
		if (type == ShapeType.CIRCLE) return Type.Circle;
		if (type == ShapeType.EDGE) return Type.Edge;
		if (type == ShapeType.POLYGON) return Type.Polygon;
		if (type == ShapeType.CHAIN) return Type.Chain;
		return Type.Circle;
	}

	/** Returns the shape of this fixture */
	public Shape getShape () {
		if (shape == null) {
			org.jbox2d.collision.shapes.Shape shape2 = fixture.getShape();
			ShapeType type = shape2.getType();
			if (type == ShapeType.CHAIN) shape = new ChainShape((org.jbox2d.collision.shapes.ChainShape)shape2);
			if (type == ShapeType.CIRCLE) shape = new CircleShape((org.jbox2d.collision.shapes.CircleShape)shape2);
			if (type == ShapeType.EDGE) shape = new EdgeShape((org.jbox2d.collision.shapes.EdgeShape)shape2);
			if (type == ShapeType.POLYGON) shape = new PolygonShape((org.jbox2d.collision.shapes.PolygonShape)shape2);
		}
		return shape;
	}

	/** Set if this fixture is a sensor. */
	public void setSensor (boolean sensor) {
		fixture.setSensor(sensor);
	}

	/** Is this fixture a sensor (non-solid)?
	 * @return the true if the shape is a sensor. */
	public boolean isSensor () {
		return fixture.isSensor();
	}

	/** Set the contact filtering data. This will not update contacts until the next time step when either parent body is active and
	 * awake. This automatically calls Refilter. */
	public void setFilterData (Filter filter) {
		org.jbox2d.dynamics.Filter f = new org.jbox2d.dynamics.Filter();
		f.categoryBits = filter.categoryBits;
		f.groupIndex = filter.groupIndex;
		f.maskBits = filter.maskBits;
		fixture.setFilterData(f);
	}

	/** Get the contact filtering data. */
	private final Filter filter = new Filter();

	public Filter getFilterData () {
		org.jbox2d.dynamics.Filter f = fixture.getFilterData();
		filter.categoryBits = (short)f.categoryBits;
		filter.maskBits = (short)f.maskBits;
		filter.groupIndex = (short)f.groupIndex;
		return filter;
	}

	/** Call this if you want to establish collision that was previously disabled by b2ContactFilter::ShouldCollide. */
	public void refilter () {
		fixture.refilter();
	}

	/** Get the parent body of this fixture. This is NULL if the fixture is not attached. */
	public Body getBody () {
		return body;
	}

	final Vec2 tmp = new Vec2();

	/** Test a point for containment in this fixture.
	 * @param p a point in world coordinates. */
	public boolean testPoint (Vector2 p) {
		tmp.set(p.x, p.y);
		return fixture.testPoint(tmp);
	}

	/** Test a point for containment in this fixture.
	 * @param x the x-coordinate
	 * @param y the y-coordinate */
	public boolean testPoint (float x, float y) {
		tmp.set(x, y);
		return fixture.testPoint(tmp);
	}

	/** Set the density of this fixture. This will _not_ automatically adjust the mass of the body. You must call
	 * b2Body::ResetMassData to update the body's mass. */
	public void setDensity (float density) {
		fixture.setDensity(density);
	}

	/** Get the density of this fixture. */
	public float getDensity () {
		return fixture.getDensity();
	}

	/** Get the coefficient of friction. */
	public float getFriction () {
		return fixture.getFriction();
	}

	/** Set the coefficient of friction. */
	public void setFriction (float friction) {
		fixture.setFriction(friction);
	}

	/** Get the coefficient of restitution. */
	public float getRestitution () {
		return fixture.getRestitution();
	}

	/** Set the coefficient of restitution. */
	public void setRestitution (float restitution) {
		fixture.setRestitution(restitution);
	}

	/** Sets custom user data. */
	public void setUserData (Object userData) {
		this.userData = userData;
	}

	/** @return custom user data */
	public Object getUserData () {
		return userData;
	}
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy