zoukankan      html  css  js  c++  java
  • 【Android游戏开发二十】物理游戏之重力系统开发,让你的游戏变得有质有量!

    Himi  原创, 欢迎转载,转载请在明显处注明! 谢谢。

    原文地址:http://blog.csdn.net/xiaominghimi/archive/2011/01/19/6153396.aspx

        今天群里一哥哥说急需关于物理游戏方面的资料,so~下午就随手写了一个简单的圆形自由落体Demo,正好一起分享给大家学习下吧;

        先大概说一下,之前的文章中,给大家介绍过重力传感器,那么和今天要说的重力系统,其实是一样的!

        在重力传感器中,虽然我也实现了一个圆形会根据手机反转的角度而拥有不同的速度,但是其内置加速度算法都是Android os封装好的,而今天我们要讲的重力系统就是去模拟这个加速度,从而让一个自由落体的圆形,感觉跟现实中的皮球一样有质有量!下落的时候速度加快,反弹起来以后速度慢慢减下来~

    OK,先上两张截图,然后简单介绍之后进行讲解:

                               

    Demo:简介:(咳咳、玩的有点H,狂点按钮搞的满屏都是 - -)

          当你点击模拟器任意按键的时候会随机在屏幕上生成一个随机大小、随即颜色、随即位置、不停闪烁的一个圆形,并且圆形都拥有重力,在做自由落体,当圆形触到屏幕底部的时候会反弹,并且反弹的高度一次比一次低!

          这个实例中,为了好看,我没有让圆形最终慢到停下来,会一直在一个高度进行的反弹,下落;

    还有一点:对于圆形当从一个高度自由落体的时候可能它在X坐标系上没有发生改变,当然这是在我们代码中,属于理想状态,因为现实生活中,一般X/Y坐标系都会有变动,在此Demo中,我主要把垂直下落并且反弹的功能做出来了,关于水平的加速度我没做,第一是因为和垂直的处理思路基本一致,第二点我没时间 - -...

    好了 不废话!先介绍一下我自定义的圆形类:

    MyArc.java


     

    代码比较简单主要讲解下几个备注:

    备注1:

           估计有些同学看到这里有点小晕,我解释下,大家都知道自由落体的时候,速度是越来越快的,这是受到加速度的影响,所以这里我们对原有的圆形y速度基础上再加上加速度! 

    备注2:

           虽然加速度影响了圆形原有的速度,但是我们的加速度也不是恒定的,为了模拟真实球体的自由下落,这里我们不仅对加速度增加了偏移量ACC,而且我们还要对其变化的规律进行模拟,让下次的加速度偏移量成倍增加!所以为什么要for循环的时候把加速度的值当成for循环的一个判定条件!

    好了,下面来看我们SurfaceView!

     

    OK,代码都很简单,也很清晰! 稍微说一句:像MyArc里面也有类似MysurfaceView中一样的方法 logic() 以及draw()这样是更好的管理我们的代码结构,清晰思路,让该干什么的就去干什么,这样省的乱~  

    源码下载地址:http://download.csdn.net/source/2992517

                               补充下://备注1 这里!有的童鞋说for循环可以简写:这我就要提示各位童鞋了~

    for (int i = 0; i < count; i++) { 

             vertical_speed += ACC;

    } 

    以上代码确实可以用一句来表示:

                   vertical_speed +=ACC*count;     或者    vertical_speed  =vertical_speed + ACC*count;

    但是要注意:因为我这里变量都是浮点数,大家都知道对于浮点数有位数的限制,那么我这里用for来写可以避免乘积,如果简写的形式会有造成得到的结果有差异!!!!所以要注意;

                   还有千万不要简写成 vertical_speed =(vertical_speed +ACC)*count; 这是错误的!

      

  • 相关阅读:
    ACM_求f(n)
    ACM_四数之和
    jQuery 3D旋转展示焦点图
    jQuery+CSS3动画相册特效
    jQuery/CSS3实现Android Dock效果
    html5/CSS3鼠标滑过图片特效插件
    CSS3定时提示动画特效
    日期选择插件
    HTML5/CSS3淡入淡出滑块焦点图
    HTML5/CSS3动画下拉菜单
  • 原文地址:https://www.cnblogs.com/encounter/p/2188429.html
Copyright © 2011-2022 走看看