美文网首页viewAndroid特效开发Android知识
JBox2D运用-打造摩拜单车贴纸动画效果

JBox2D运用-打造摩拜单车贴纸动画效果

作者: SyncAny | 来源:发表于2017-07-23 18:31 被阅读1198次
ANGRYBIRDS

1. 准备工作

**1. 在github上下载JBox2d源码:https://github.com/jbox2d/jbox2d **

2. 安装并配置本地maven仓库环境

  1. 下载maven,选择apache-maven-3.5.0-bin下载(可随意选择不同版本):http://maven.apache.org/download.cgi

  2. 配置环境变量 :

> 1.新建 `MAVEN_HOME : E:\maven\apache-maven-3.5.0`
 
> 2.添加 path: `E:\maven\apache-maven-3.5.0\bin`  或者  `;%MAVEN_HOME\bin%`

3.cmd中执行命令mvn -v检测maven安装是否成功,出现版本号即成功。

  1. 修改本地maven仓库地址:

    1.在本地maven的目录下修改setting.xml文件中的内容:
    E:\maven\apache-maven-3.5.0\conf\settings.xml
    在相应的位置增加下面这句话:
    <localRepository>D:\maven\repository</localRepository>

    2.修改本地maven仓库地址截图


    自定义本地maven仓库地址

    3.验证修改是否成功,cmd中执行如下命令 : mvn help:system
    之后会下载一些相关的配置文件,我们到刚刚定义的目录查看会多出很多文件夹,说明修改OK。

    4.如果查看本地maven地址 : mvn help:effective-settings
    cmd中执行命令之后会看到下面的输出,里面有本地maven仓库地址

    查看本地maven仓库地址

3. 将从github下载的源码通过命令转化为gradle工程

  1. 进入要转化为gradle工程的目录下,找到pom.xml文件,
    例如:F:\jbox2d\jbox2d-master\jbox2d-library

  2. 在工程目录下cmd执行命令 : gradle init --type pom

  3. 转化成果出现如下提示,并且目录下增加gradle的配置文件

maven转gradle成功

4. 将上面转化的工程导入AS,并编译成jar包的形式,以供使用。

  1. 编译jar包时可以选择:
    Android Studio右侧的Gradle下面对应的Tasks\build\assemble,
    或者Android Studio下方的Terminal命令窗口执行命令:gradlew assemble

  2. 这时候如果出现如下错误:

Tasks\build\assemble下编译出错,不过没有直接显示错误


编译出错

Terminal下命令编译出错


命令行编译出错
  1. 可以看到编译之后,路径出现问题,我们看一下路径修改一下即可,

修改之前的路径是:org.jbox2d.common

修改路径
  1. 再次执行命令编译就可得到生成的jar包
编译成功生成jar

5. 编译jar包也可以通过执行maven命令来实现

  1. 在工程目录下,cmd执行命令 : mvn install就会生成我们需要的jar包,
    注意的是mvn编译生成的文件和jar都在target目录下。

  2. 生成jar的目录在工程的target目录下

maven命令编译

2. 开始编码

1.项目效果图如下 :

初始进入 碰撞完成

2. github源码地址 : https://github.com/AmiGWF/JBox2dInAndroid

3. 项目说明

  1. 这里用到的jbox2d引擎是通过jar的方式引入的,也可以直接下载jbox2d的源码导入引用。

  2. 项目中实现目前只需要一个自定义view和一个实现类,相对比较简单,实现类中的相关逻辑可以参考jbo2d的文档。建议先看下文档,再进行编码, 文档在github项目的assest下。

  3. 源码简要分析
    JBoxCollisionImpl 球体碰撞主要实现类
    1.部分参数说明

   /**
    * 模拟世界中进行一次迭代模拟world.step所需参数
    * 迭代频率
    * 迭代速率
    * 迭代次数
    */
    private float dt = 1f / 60f;
    private int velocityIterations = 5;
    private int positionIterations = 20;

    private int mProportion = 50;  // 模拟世界和view坐标的转化比例
    private float mDensity = 0.6f;  //密度
    private float mFrictionRatio = 0.8f;  //摩擦系数
    private float mRestitutionRatio = 0.6f;  //恢复系数

2.部分方法说明

private void createBody(View view) {
        BodyDef bodyDef = new BodyDef();
        bodyDef.type = BodyType.DYNAMIC;  //动态的刚体

        bodyDef.position.set(mappingView2Body(view.getX() + view.getWidth() / 2), 
mappingView2Body(view.getY() + view.getHeight() / 2));  //设置重心位置,即圆心

        Shape shape = null;
        Boolean isCircle = (Boolean) view.getTag(R.id.wd_view_circle_tag);
        if (isCircle != null && isCircle) {
            shape = createCircleBody(view);  // 创建形状为圆形的钢体
        } else {
            shape = createPolygonBody(view);
        }

        FixtureDef def = new FixtureDef();
        def.shape = shape;
        def.density = mDensity;
        def.friction = mFrictionRatio;
        def.restitution = mRestitutionRatio;

        Body body = mWorld.createBody(bodyDef);
        body.createFixture(def);
        view.setTag(R.id.wd_view_body_tag, body);

        body.setLinearVelocity(new Vec2(random.nextFloat(), random.nextFloat()));  //设置球体运动的线性速度,这里使用的是随机值
    }
//  重绘不同球体的位置
public void onDraw() {
        if (mWorld != null) {
            mWorld.step(dt, velocityIterations, positionIterations);
        }
        int count = viewGroup.getChildCount();
        for (int i = 0; i < count; i++) {
            View view = viewGroup.getChildAt(i);
            if (isBodyView(view)) {
                view.setX(getViewX(view));
                view.setY(getViewY(view));
                view.setRotation(getViewRotaion(view));
            }
        }
        viewGroup.invalidate();
    }
//  设置模拟世界上下(左右)的边界
 private void updateTopAndBottomBounds() {
        BodyDef bodyDef = new BodyDef();
        bodyDef.type = BodyType.STATIC;  // 这里是静态的,因为不需要移动

        PolygonShape shape = new PolygonShape();
        float hx = mappingView2Body(mWorldWidth);
        float hy = mappingView2Body(mProportion);
        shape.setAsBox(hx, hy);

        FixtureDef def = new FixtureDef();
        def.shape = shape;
        def.density = mDensity;
        def.friction = mFrictionRatio;
        def.restitution = mRestitutionRatio;

        bodyDef.position.set(0, -hy);
        Body topBody = mWorld.createBody(bodyDef);
        topBody.createFixture(def);

        bodyDef.position.set(0, mappingView2Body(mWorldHeight) + hy);
        Body bottomBody = mWorld.createBody(bodyDef);
        bottomBody.createFixture(def);
    }

相关文章

  • JBox2D运用-打造摩拜单车贴纸动画效果

    1. 准备工作 **1. 在github上下载JBox2d源码:https://github.com/jbox2d...

  • Android开发中的日常积累

    开发过程中看到的好的资源 1、图片模糊处理 2、fragment管理框架 3、使用jbox2d物理引擎打造摩拜单车...

  • iOS 高仿摩拜单车我的贴纸效果

    高仿摩拜单车我的贴纸效果 昨天在看摩拜单车APP时发现了一个有趣的地方,如下图。多个小球可以随手机的晃动而滚动,并...

  • 博应用测评ofo小黄车和摩拜单车软件哪个更好骑

    摩拜单车app是一款为用户便捷出行打造的共享单车软件,摩拜电话,使用摩拜单车app能够轻松的在手机上搜寻到附近空闲...

  • 摩拜单车产品分析

    背景介绍 最近已经被摩拜单车刷屏了,看一下摩拜单车的定义。 摩拜单车,英文名mobike,是由北京摩拜科技有限公司...

  • 无摩拜app客户端客服电话

    关于摩拜单车摩拜单车客服电话 a155155/ 摩拜单车创建、了全球首个智能共享单车模式,其自主研发的专利智能锁集...

  • 共享单车魔咒,没有资本就没有生存

    摩拜单车已全面接入美团APP,将成为美团LBS平台单车事业部,未来摩拜单车将更名为美团单车,这标志着摩拜单车独立发...

  • 今天我骑摩拜单车上班

    今天我骑摩拜单车上班。 问: 摩拜单车是什么? 答:摩拜单车是一种共享型自行车。 摩拜统一定制的小橙车可以停在路边...

  • 岗位责任

    一.岗位包括 1.摩拜单车运营协助员; 2.摩拜单车运营协助员区域负责人; 3.摩拜单车猎人。 二. 工作责任考核...

  • 单车月卡汇总

    【摩拜单车】月卡 点击“免费领取”按钮:摩拜单车新用户可获得1张月卡,免费骑行30天且不限骑行次数;摩拜单车老用户...

网友评论

    本文标题:JBox2D运用-打造摩拜单车贴纸动画效果

    本文链接:https://www.haomeiwen.com/subject/zfpmkxtx.html