热门标签 | HotTags
当前位置:  开发笔记 > 运维 > 正文

Android物理游戏之重力系统开发示例代码

介绍Android物理游戏之重力系统,这里提供了详细的资料整理,并附示例代码和实现效果图,有兴趣的小伙伴可以参考下

本节为大家提供有关物理游戏的知识,讲解了一个简单的圆形自由落体Demo的编写。本文要介绍的重力系统实际上是类似的。

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

       先贴上两张效果截图,让大家有一个直观的了解,之后再详加讲解:

圆形自由落体Demo简介

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

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

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

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

Java代码

package com.himi;  
import java.util.Random;  
import android.graphics.Canvas;  
import android.graphics.Color;  
import android.graphics.Paint;  
import android.graphics.RectF;  
/** 
 * @author Himi 
 * @自定义圆形类 
 */ 
public class MyArc {  
  private int arc_x, arc_y, arc_r;//圆形的X,Y坐标和半径  
  private float speed_x = 1.2f, speed_y = 1.2f;//小球的x、y的速度  
  private float vertical_speed;//加速度  
  private float horizontal_speed;//水平加速度,大家自己试着添加吧  
  private final float ACC = 0.135f;//为了模拟加速度的偏移值  
  private final float RECESSION = 0.2f;//每次弹起的衰退系数  
  private boolean isDown = true;//是否处于下落 状态  
  private Random ran;//随即数库  
  /** 
   * @定义圆形的构造函数 
   * @param x 圆形X坐标 
   * @param y 圆形Y坐标 
   * @param r 圆形半径 
   */ 
  public MyArc(int x, int y, int r) {  
    ran = new Random();  
    this.arc_x = x;  
    this.arc_y = y;  
    this.arc_r = r;  
  }  
  public void drawMyArc(Canvas canvas, Paint paint) {//每个圆形都应该拥有一套绘画方法  
    paint.setColor(getRandomColor());//不断的获取随即颜色,对圆形进行填充(实现圆形闪烁效果)  
    canvas.drawArc(new RectF(arc_x + speed_x, arc_y + speed_y, arc_x + 2 *  
        arc_r + speed_x, arc_y + 2 * arc_r + speed_y), 0, 360, true, paint);  
  }  
  /** 
   * @return 
   * @返回一个随即颜色 
   */ 
  public int getRandomColor() {  
    int ran_color = ran.nextInt(8);  
    int temp_color = 0;  
    switch (ran_color) {  
    case 0:  
      temp_color = Color.WHITE;  
      break;  
    case 1:  
      temp_color = Color.BLUE;  
      break;  
    case 2:  
      temp_color = Color.CYAN;  
      break;  
    case 3:  
      temp_color = Color.DKGRAY;  
      break;  
    case 4:  
      temp_color = Color.RED;  
      break;  
    case 6:  
      temp_color = Color.GREEN;  
    case 7:  
      temp_color = Color.GRAY;  
    case 8:  
      temp_color = Color.YELLOW;  
      break;  
    }  
    return temp_color;  
  }  
  /** 
   * 圆形的逻辑 
   */ 
  public void logic() {//每个圆形都应该拥有一套逻辑  
    if (isDown) {//圆形下落逻辑  
/*--备注1-*/speed_y += vertical_speed;//圆形的Y轴速度加上加速度  
      int count = (int) vertical_speed++;  
      //这里拿另外一个变量记下当前速度偏移量  
      //如果下面的for (int i = 0; i = MySurfaceViee.screenH;  
  }  
} 

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

       备注1:

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

       这里有的童鞋说for循环可以简写,那我就要提示各位了:

 for (int i = 0; i 

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

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

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

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

       备注2:

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

       好了,下面来看我们SurfaceView。

package com.himi;  
import java.util.Random;  
import java.util.Vector;  
import android.content.Context;  
import android.graphics.Canvas;  
import android.graphics.Color;  
import android.graphics.Paint;  
import android.util.Log;  
import android.view.KeyEvent;  
import android.view.SurfaceHolder;  
import android.view.SurfaceView;  
import android.view.SurfaceHolder.Callback;  
public class MySurfaceViee extends SurfaceView implements Callback, Runnable {  
  private Thread th;  
  private SurfaceHolder sfh;  
  private Canvas canvas;  
  private Paint paint;  
  private boolean flag;  
  public static int screenW, screenH;  
  private Vector vc;//这里定义装我们自定义圆形的容器  
  private Random ran;//随即库  
  public MySurfaceViee(Context context) {  
    super(context);  
    this.setKeepScreenOn(true);  
    vc = new Vector();  
    ran = new Random();//备注1  
    sfh = this.getHolder();  
    sfh.addCallback(this);  
    paint = new Paint();  
    paint.setAntiAlias(true);  
    setFocusable(true);  
  }  
  public void surfaceCreated(SurfaceHolder holder) {  
    flag = true;//这里都是上一篇刚讲过的。。。  
    th = new Thread(this);  
    screenW = this.getWidth();  
    screenH = this.getHeight();  
    th.start();  
  }  
  public void draw() {  
    try {  
      canvas = sfh.lockCanvas();  
      canvas.drawColor(Color.BLACK);  
      if (vc != null) {//当容器不为空,遍历容器中所有圆形画方法  
        for (int i = 0; i 

        OK,代码都很简单,也很清晰! 稍微说一句:像MyArc里面也有类似MysurfaceView中一样的方法 logic() 以及draw(),这样能更好的管理我们的代码结构,思路清晰,各尽其责,避免混乱。

        以上就是对Android 开发重力系统的资料整理,后续继续补充相关资料,谢谢大家对本站的支持!


推荐阅读
  • 在Android开发中,使用Picasso库可以实现对网络图片的等比例缩放。本文介绍了使用Picasso库进行图片缩放的方法,并提供了具体的代码实现。通过获取图片的宽高,计算目标宽度和高度,并创建新图实现等比例缩放。 ... [详细]
  • 云原生边缘计算之KubeEdge简介及功能特点
    本文介绍了云原生边缘计算中的KubeEdge系统,该系统是一个开源系统,用于将容器化应用程序编排功能扩展到Edge的主机。它基于Kubernetes构建,并为网络应用程序提供基础架构支持。同时,KubeEdge具有离线模式、基于Kubernetes的节点、群集、应用程序和设备管理、资源优化等特点。此外,KubeEdge还支持跨平台工作,在私有、公共和混合云中都可以运行。同时,KubeEdge还提供数据管理和数据分析管道引擎的支持。最后,本文还介绍了KubeEdge系统生成证书的方法。 ... [详细]
  • Android中高级面试必知必会,积累总结
    本文介绍了Android中高级面试的必知必会内容,并总结了相关经验。文章指出,如今的Android市场对开发人员的要求更高,需要更专业的人才。同时,文章还给出了针对Android岗位的职责和要求,并提供了简历突出的建议。 ... [详细]
  • 《数据结构》学习笔记3——串匹配算法性能评估
    本文主要讨论串匹配算法的性能评估,包括模式匹配、字符种类数量、算法复杂度等内容。通过借助C++中的头文件和库,可以实现对串的匹配操作。其中蛮力算法的复杂度为O(m*n),通过随机取出长度为m的子串作为模式P,在文本T中进行匹配,统计平均复杂度。对于成功和失败的匹配分别进行测试,分析其平均复杂度。详情请参考相关学习资源。 ... [详细]
  • 在Docker中,将主机目录挂载到容器中作为volume使用时,常常会遇到文件权限问题。这是因为容器内外的UID不同所导致的。本文介绍了解决这个问题的方法,包括使用gosu和suexec工具以及在Dockerfile中配置volume的权限。通过这些方法,可以避免在使用Docker时出现无写权限的情况。 ... [详细]
  • 胡蜂能进行逻辑推理的研究成果
    最新研究表明,胡蜂具备一定的逻辑推理能力,能够进行传递性推理。研究人员通过实验发现,胡蜂在避免电击的测试中,能够正确选择符合逻辑的选项。这项研究成果对于了解无脊椎动物的认知能力具有重要意义,也为解析胡蜂社会结构的进化提供了线索。 ... [详细]
  • Java容器中的compareto方法排序原理解析
    本文从源码解析Java容器中的compareto方法的排序原理,讲解了在使用数组存储数据时的限制以及存储效率的问题。同时提到了Redis的五大数据结构和list、set等知识点,回忆了作者大学时代的Java学习经历。文章以作者做的思维导图作为目录,展示了整个讲解过程。 ... [详细]
  • 阿,里,云,物,联网,net,core,客户端,czgl,aliiotclient, ... [详细]
  • Spring特性实现接口多类的动态调用详解
    本文详细介绍了如何使用Spring特性实现接口多类的动态调用。通过对Spring IoC容器的基础类BeanFactory和ApplicationContext的介绍,以及getBeansOfType方法的应用,解决了在实际工作中遇到的接口及多个实现类的问题。同时,文章还提到了SPI使用的不便之处,并介绍了借助ApplicationContext实现需求的方法。阅读本文,你将了解到Spring特性的实现原理和实际应用方式。 ... [详细]
  • 本文介绍了Hyperledger Fabric外部链码构建与运行的相关知识,包括在Hyperledger Fabric 2.0版本之前链码构建和运行的困难性,外部构建模式的实现原理以及外部构建和运行API的使用方法。通过本文的介绍,读者可以了解到如何利用外部构建和运行的方式来实现链码的构建和运行,并且不再受限于特定的语言和部署环境。 ... [详细]
  • 本文详细介绍了Linux中进程控制块PCBtask_struct结构体的结构和作用,包括进程状态、进程号、待处理信号、进程地址空间、调度标志、锁深度、基本时间片、调度策略以及内存管理信息等方面的内容。阅读本文可以更加深入地了解Linux进程管理的原理和机制。 ... [详细]
  • 1,关于死锁的理解死锁,我们可以简单的理解为是两个线程同时使用同一资源,两个线程又得不到相应的资源而造成永无相互等待的情况。 2,模拟死锁背景介绍:我们创建一个朋友 ... [详细]
  • 后台获取视图对应的字符串
    1.帮助类后台获取视图对应的字符串publicclassViewHelper{将View输出为字符串(注:不会执行对应的ac ... [详细]
  • XML介绍与使用的概述及标签规则
    本文介绍了XML的基本概念和用途,包括XML的可扩展性和标签的自定义特性。同时还详细解释了XML标签的规则,包括标签的尖括号和合法标识符的组成,标签必须成对出现的原则以及特殊标签的使用方法。通过本文的阅读,读者可以对XML的基本知识有一个全面的了解。 ... [详细]
  • Google Play推出全新的应用内评价API,帮助开发者获取更多优质用户反馈。用户每天在Google Play上发表数百万条评论,这有助于开发者了解用户喜好和改进需求。开发者可以选择在适当的时间请求用户撰写评论,以获得全面而有用的反馈。全新应用内评价功能让用户无需返回应用详情页面即可发表评论,提升用户体验。 ... [详细]
author-avatar
款款迷恋_420
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有