Android游戏开发教程——(绘制屏幕)「建议收藏」

游戏开发的基本原理:启动一个Activity对象,然后让其显示一个GameCanvas对象(setContentView(GameCanvas));,GameCanvas 里面做游戏逻辑,用户键盘或屏幕输入,屏幕的绘制等这些工作。 那具体怎么做呢?说到重点了。先来讲GameCanvas(游戏画布) 。这是一个类,也就是我们游戏的画布。开发游戏的时候大部分

大家好,又见面了,我是全栈君。

游戏开发的基本原理:

启动一个Activity对象,然后让其显示一个GameCanvas对象(setContentView(GameCanvas));,

GameCanvas 里面做游戏逻辑,用户键盘或屏幕输入,屏幕的绘制等这些工作。 那具体怎么做呢?说到重点了。

先来讲GameCanvas(游戏画布) 。这是一个类,也就是我们游戏的画布。开发游戏的时

候大部分的工作都会在这里面完成的 。那么在android 里面 怎样构成我们的GameCanvas。这里我用了

SurfaceView 类,使用这个类的原因是它比较适合游戏画布。然后我们再继承SurfaceHolder.Callback 这个接口

,这样我们的GameCanvas类要实现其几个方法

1 public void surfaceCreated(SurfaceHolder holder) {}
2 public void surfaceDestroyed(SurfaceHolder holder) {}
3 public void surfaceChanged(SurfaceHolder holder, int format, int width, int height) {}

我们在surfaceCreated 方法里面初始化游戏,

在surfaceChanged 处理一下当手机碰到外界情况的事件,

在surfaceDestroyed 方法里面我们写释放资源等。

这样每个方法里面都会有个参数 SurfaceHolder 这个是什么呢??暂且先不讨论它,后面你会明白他有什么用了,

声明一个SurfaceHolder handle对象,然后在surfaceCreated()方法里面初始化它 

如下:

handle = this.getHolder(); 
handle.addCallback(this);

那在哪里绘制我们的游戏画布呢?讲到关键的地方了,这里我们重载view 的 public void draw(Canvas canvas){}方法,

我们就在这个方法里面绘制我们的游戏。

游戏大体框架如下:

public class GameCanvas extends SurfaceView implements SurfaceHolder.Callback{ private SurfaceHolder handle = null; private int width = 0; private int height = 0; public GameCanvas(){  handle = this.getHolder();  handle.addCallback(this); } public void initGame(){  width = this.getWidth();  height = this.getHeight(); } public void gameLogic(){} public void gameInput(){} @Override public void draw(Canvas canvas){  Paint paint = new Paint(Paint.ANTI_ALIAS_FLAG);  paint.setColor(Colcor.Black);  canvas.drawRect(new Rect(int startX,int StartY,int endX,int endY));//此处的Rect跟java里面的有点区别,自己写坐标就行,上面的语句是将屏幕绘制成黑色  paint.setColor(Cloor.red);  canvas.drawText("Andoid GameCanvas",100,100,paint); } @Override public void surfaceCreated(SurfaceHolder holder) {  this.initGame();  new Thread(this){   public void run(){    while(true) {     long start=System.currentTimeMillis();     Canvas canvas = GameCanvas.this.handle.lockCanvas(null);     this.draw(canvas);     canvas.save();     GameCanvas.this.handle.unlockCanvasAndPost(canvas);    }   }.start();} long end=System.currentTimeMillis(); if(100>end-start){  try{   Thread.sleep(100-(end-start));  }catch(Exception e){  } } @Override public void surfaceDestroyed(SurfaceHolder holder) { } @Override public void surfaceChanged(SurfaceHolder holder, int format, int width,int height){} }

好了,游戏框架已经打好了。当你运行一下程序,你会看到手机屏幕被绘制成了黑色,在坐标(100,100)处显示文本:Andoid GameCanvas

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/121485.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • C#并发实战Parallel.ForEach使用

    C#并发实战Parallel.ForEach使用前言:最近给客户开发一个伙食费计算系统,大概需要计算2000个人的伙食。需求是按照员工的预定报餐计划对消费记录进行检查,如有未报餐有刷卡或者有报餐没刷卡的要进行一定的金额扣减等一系列规则。一开始我的想

    2022年7月4日
    25
  • ldd命令 ubuntu_使用示例解释Linux ldd命令

    ldd命令 ubuntu_使用示例解释Linux ldd命令用例子说明Linuxldd命令如果您的工作涉及到Linux中的可执行文件和共享库的深入知识,则需要了解几种命令行工具。其中之一是ldd,您可以使用它来访问共享对象依赖关系。在本教程中,我们将使用一些易于理解的示例来讨论此实用程序的基础知识。请注意,这里提到的所有示例都已在Ubuntu16.04LTS上进行了测试。Linuxldd命令正如开头已经提到的,ldd命令打印共享对象依赖关系。…

    2022年5月3日
    61
  • 转录组测序火山图_转录组差异基因筛选标准

    转录组测序火山图_转录组差异基因筛选标准利用R包DEseq2进行差异表达分析和可视化count数矩阵在Linux下,通过HISAT2对下载的GSE数据进行比对,FeatureCounts软件进行基因水平定量,得到count数矩阵。之后便可以载入R语言中进行差异分析。差异分析第一次分析RNA-seq数据,走到这一步相对容易了许多。转录组数据分析主要参考了生信技能树Jimmy老师的相关课程及推文。RNA-seq的readcount普遍认为符合泊松分布,但是之前分析过的芯片数据符合正态分布,所以筛选DEGs的方法有一定差别。.

    2022年8月30日
    3
  • Brocade 光纤交换机级联配置「建议收藏」

    Brocade 光纤交换机级联配置「建议收藏」一、需求说明两台Brocade光纤交换机做级联二、检查级联许可:首先分别核查两台设备是都均具有级联License:1、通过licenseshow命令查看:三、更改DomainID修改switchdomainID,确保两台switch的domainID唯一1、运行switchshow命令确认当前的domainID:switch:admin>…

    2022年5月21日
    144
  • IntellijIdea 非Maven项目打Jar包

    IntellijIdea 非Maven项目打Jar包  一、以SpringBoot项目为例,在未使用maven的情况下将其打成Jar包。  二、将其打成散包,即项目依赖的Jar包在目录同级或子级。好处是如果项目更新,只需要更新项目的jar,不需要更新所有。  一、检查项目是否包含META-INF文件夹。     若包含META-INF文件夹,将其删除。等下重新生成。  二、构建Artifacts  2.1选择菜…

    2022年6月19日
    157
  • SRC挖掘—web不安全的直接对象引用 (IDOR)漏洞-3day

    SRC挖掘—web不安全的直接对象引用 (IDOR)漏洞-3day什么是IDOR?当应用程序根据用户提供的输入提供对对象的直接访问时,就会发生不安全的直接对象引用(IDOR)。由于此漏洞,攻击者可以绕过授权并直接访问系统中的资源,例如数据库记录或文件。不安全的直接对象引用允许攻击者通过修改用于直接指向对象的参数值来绕过授权并直接访问资源。这些资源可以是属于其他用户的数据库条目、系统中的文件等等。这是因为应用程序接受用户提供的输入并使用它来检索对象而没有执行足够的授权检查。(来源:OWASP)让我们看一个例子。想象一下,您正在使用一个文档共享平台。您可以上传..

    2022年6月5日
    36

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号