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

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);
    }
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,837评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,551评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,417评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,448评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,524评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,554评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,569评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,316评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,766评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,077评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,240评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,912评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,560评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,176评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,425评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,114评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,114评论 2 352

推荐阅读更多精彩内容