PhysicsLayout
Android layout that simulates physics using JBox2D. Simply add views, enable physics, and watch them fall!
Gradle Dependency
Add this in your root build.gradle
file (not your module build.gradle
file):
allprojects {
repositories {
...
maven { url "https://jitpack.io" }
}
}
Then, add the library to your project build.gradle
dependencies {
compile 'com.github.Jawnnypoo:PhysicsLayout:2.1.0'
}
Basic Usage
If you want to see what your layout looks like when physics is applied to it, simply change your root layout to a physics layout.
<com.jawnnypoo.physicslayout.PhysicsLinearLayout
android:id="@+id/physics_layout"
android:layout_width="match_parent"
android:layout_height="200dp">
<ImageView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:src="@drawable/ic_launcher"/>
<ImageView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:src="@drawable/ic_launcher"/>
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Hello world, I have physics!"/>
</com.jawnnypoo.physicslayout.PhysicsLinearLayout>
Custom XML Attributes
You can also further customize the behaviour of your PhysicsLayout
<com.jawnnypoo.physicslayout.PhysicsLinearLayout
android:id="@+id/physics_layout"
android:layout_width="match_parent"
android:layout_height="200dp"
app:physics="true"
app:gravityX="0.0"
app:gravityY="9.8"
app:bounds="true"
app:boundsSize="50dp"/>
physics
boolean, Determines if physics will be applied to the layout (Default true)gravityX
float, Sets the gravity in the X direction (positive is right, negative is left) (Default 0)gravityY
float, Sets the gravity in the Y direction (positive is down, negative is up) (Default 9.8)bounds
boolean, Determines if the layout should have bounds on the edges of itself (Default true)boundsSize
dimenstion, Sets the width/height of the bounds on the edges (Default 20dp)
Custom Physics Configuration
Each view contained within the layout has a physics configuration that it uses to create itself in the Box2D world. This defines its shape, mass, restitutaion, and other physics related variables. A custom configuration can be applied to each view as well:
<TextView
android:id="@+id/text"
android:layout_width="20dp"
android:layout_height="20dp"
app:layout_shape="circle"
app:layout_circleRadius="20dp"
app:layout_bodyType="kinematic"
app:layout_fixedRotation="true"
app:layout_friction="0.8"
app:layout_restitution="0.3"
app:layout_density="0.5" />
or alternatively, the Physics definition can be made programmatically:
final View circleView = findViewById(R.id.circle);
PhysicsConfig config = PhysicsConfig.create();
config.shapeType = PhysicsConfig.SHAPE_TYPE_CIRCLE;
config.radius = dpToPx(30);
config.fixtureDef = fixtureDef;
config.bodyDef = bodyDef;
Physics.setPhysicsConfig(circleView, config);
This is useful especially if you have view that would be considered circular, as the default for all views is a RETANGLE shape type. Most of the time, if you are just dealing with rectangular views, the defaults will work for you and you will not have to worry about this.
Check out the sample app to see most of these things in action.
Live Demo
https://play.google.com/store/apps/details?id=com.jawnnypoo.physicslayout.sample