package com.easyway.dev.android.snake;
import android.content.Context;
import android.content.res.TypedArray;
import android.graphics.Bitmap;
import android.graphics.Canvas;
import android.graphics.Paint;
import android.graphics.drawable.Drawable;
import android.util.AttributeSet;
import android.view.View;
/**
* Android 平台裡,使用者介面都是透过 ViewGroup 或 View 类别来显示。
* ViewGroup 和 View 是 Android 平台上最基本的使用者介面表达单元。我
* 们可以透过程式直接呼叫的方法,调用描绘使用者介面,将萤幕上显示的介面元
* 素,与构成应用程式主体的程式逻辑,溷合在一起编写。或是,也可以将介面显示
* 与程式逻辑分离,照着 Android 提供的这个较优雅的方式,使用 XML 描述档,
* 来描述介面元件的组织。
*
* 在 Android 系统中,我们使用 XML 来定义 UI。但是有些稍微有经验的开发者可能会有疑问:
*「用 XML 来描述介面固然方便,但是对于手机程式来说,直接用 XML 档桉是不是太占空间了?」。
*没错,如果 Android 是直接使用 XML 来储存介面描述到手机上的话,一定会佔用比起现在大的多
*的档桉空间。解决的方法是Android 并不直接使用 XML 档桉,而是透过 Android 开发工具,
*自动将 XML 描述档转换成资源档桉。一旦应用程式要操作某个介面元件,或是使用任何种类的资源
*(字串、图片、图示、音效...),都使用索引来查询。
*
*
*伟大的创意少之又少,多数时候只是一些小改进。小的改进也是好的。
*
*
* TileView: a View-variant designed for handling arrays of "icons" or other
* drawables.
*
*/
public class TileView extends View {
/**
* Parameters controlling the size of the tiles and their range within view.
* Width/Height are in pixels, and Drawables will be scaled to fit to these
* dimensions. X/Y Tile Counts are the number of tiles that will be drawn.
*/
protected static int mTileSize;
protected static int mXTileCount;
protected static int mYTileCount;
private static int mXOffset;
private static int mYOffset;
/**
*
* A hash that maps integer handles specified by the subclasser to the
* drawable that will be used for that reference
*/
private Bitmap[] mTileArray;
/**
* 声明用来存放绘画图像的x,y轴的位置的数组
* A two-dimensional array of integers in which the number represents the
* index of the tile that should be drawn at that locations
*/
private int[][] mTileGrid;
private final Paint mPaint = new Paint();
public TileView(Context context, AttributeSet attrs, int defStyle) {
super(context, attrs, defStyle);
TypedArray a = context.obtainStyledAttributes(attrs, R.styleable.TileView);
mTileSize = a.getInt(R.styleable.TileView_tileSize, 12);
a.recycle();
}
public TileView(Context context, AttributeSet attrs) {
super(context, attrs);
TypedArray a = context.obtainStyledAttributes(attrs, R.styleable.TileView);
mTileSize = a.getInt(R.styleable.TileView_tileSize, 12);
a.recycle();
}
/**
* Rests the internal array of Bitmaps used for drawing tiles, and
* sets the maximum index of tiles to be inserted
*
* @param tilecount
*/
public void resetTiles(int tilecount) {
mTileArray = new Bitmap[tilecount];
}
@Override
protected void onSizeChanged(int w, int h, int oldw, int oldh) {
mXTileCount = (int) Math.floor(w / mTileSize);
mYTileCount = (int) Math.floor(h / mTileSize);
mXOffset = ((w - (mTileSize * mXTileCount)) / 2);
mYOffset = ((h - (mTileSize * mYTileCount)) / 2);
mTileGrid = new int[mXTileCount][mYTileCount];
clearTiles();
}
/**
* Function to set the specified Drawable as the tile for a particular
* integer key.
*
* @param key
* @param tile
*/
public void loadTile(int key, Drawable tile) {
Bitmap bitmap = Bitmap.createBitmap(mTileSize, mTileSize, Bitmap.Config.ARGB_8888);
Canvas canvas = new Canvas(bitmap);
tile.setBounds(0, 0, mTileSize, mTileSize);
tile.draw(canvas);
mTileArray[key] = bitmap;
}
/**
* Resets all tiles to 0 (empty)
*
*/
public void clearTiles() {
for (int x = 0; x < mXTileCount; x++) {
for (int y = 0; y < mYTileCount; y++) {
setTile(0, x, y);
}
}
}
/**
* Used to indicate that a particular tile (set with loadTile and referenced
* by an integer) should be drawn at the given x/y coordinates during the
* next invalidate/draw cycle.
*
* @param tileindex 图片的索引
* @param x x轴的位置
* @param y y轴的位置
*/
public void setTile(int tileindex, int x, int y) {
mTileGrid[x][y] = tileindex;
}
/**
* 重写VIEW 类里面的方法。 把界线画出。
*
* 地图其实就是由图片数组拼直面成的。 面图片又是通过他的图片索引找到,并
* 在mTileGrid[x][y],获取他们的位置索引来确定图片的位置。 这样在一个
* 手机的页面就形成了,
*
*/
@Override
public void onDraw(Canvas canvas) {
super.onDraw(canvas);
for (int x = 0; x < mXTileCount; x += 1) {
for (int y = 0; y < mYTileCount; y += 1) {
if (mTileGrid[x][y] > 0) {
canvas.drawBitmap(mTileArray[mTileGrid[x][y]],
mXOffset + x * mTileSize,
mYOffset + y * mTileSize,
mPaint);
}
}
}
}
}
分享到:
相关推荐
在贪吃蛇游戏中,我们需要在循环中不断更新蛇的位置,判断是否吃到食物,以及检查蛇身是否撞到边界或自身。 2. **碰撞检测**:碰撞检测是贪吃蛇游戏中的关键部分,用于判断蛇头是否碰到食物或者蛇身。这部分通常...
《基于Android的贪吃蛇游戏app》是一款专为Android平台设计的经典游戏应用,它将我们熟知的贪吃蛇游戏融入到了移动设备中,为用户带来了便捷且趣味的娱乐体验。这款应用不仅具备了贪吃蛇游戏的所有基本功能,还可能...
【标签】"Snake"代表了这个游戏的主题,即经典的贪吃蛇游戏。这个标签表明了项目的目标是复现这款在早期手机上广泛流行的游戏,玩家通过控制蛇的移动来吃食物,每吃到一个食物,蛇的长度就会增加,同时游戏难度也会...
以下是对"android贪吃蛇游戏源码"的详细解读: 1. **用户界面(UI)设计**: - 使用Android Studio中的布局工具(如XML布局)创建游戏主界面,包含游戏区域、得分显示、开始/暂停按钮等元素。 - 游戏区域通常用一...
贪吃蛇游戏作为一种经典的电子游戏,拥有广泛的玩家群体和长久的...开发者在实践中需要深入理解Android应用的生命周期、用户界面设计、事件处理机制和游戏逻辑编写等方面的知识,才能开发出稳定、好玩的贪吃蛇游戏。
### 基于Android的贪吃蛇游戏开发 #### 一、课程实训目的及要求 本实训项目旨在通过设计和实现一款基于Android平台的贪吃蛇游戏,加深学生对Android应用开发的理解,掌握游戏开发的基本流程和技术要点。具体要求...
《Android 贪吃蛇游戏源代码解析与学习指南》 贪吃蛇游戏,作为一款经典的游戏,无论是在PC还是移动设备上,都深受玩家喜爱。Android平台上的贪吃蛇游戏,更是为开发者提供了一个良好的实践平台,让我们可以通过源...
【Android贪吃蛇游戏开发详解】 Android平台上的贪吃蛇游戏是一款经典的休闲娱乐应用,它利用设备的重力感应功能来控制游戏中的蛇移动。在本文中,我们将深入探讨这款"Android贪吃蛇(最终版)"的实现原理、关键...
在"SnakeAndroid"这个压缩包中,包含了完整的Android贪吃蛇游戏源码。通过阅读和理解这些代码,你可以学习到如何在Android环境中实现游戏循环、如何处理用户输入、如何进行图形绘制以及如何设计简单的游戏逻辑。 ...
【Android贪吃蛇游戏源码】是一个非常适合初学者和进阶者学习的Android开发资源,它提供了实现经典游戏“贪吃蛇”的完整代码。通过分析和理解这个源码,你可以深入学习Android应用开发的基本概念、游戏逻辑以及UI...
这个小项目是针对Android平台开发的一个贪吃蛇游戏的示例,旨在帮助开发者学习和理解Android应用程序的设计与实现。 在Android平台上开发贪吃蛇游戏,主要涉及以下几个关键知识点: 1. **Android Studio集成开发...
本项目旨在通过设计与开发一款基于Android平台的贪吃蛇游戏,深入学习Java程序设计基本技术,掌握Android环境下Java程序的开发技巧,熟悉游戏开发的全过程,包括需求分析、概要设计、详细设计等阶段,以及熟练运用...
【基于Android贪吃蛇游戏论文】的摘要指出,该课题旨在使用Java语言在Android平台上开发一款手机游戏。考虑到作者的知识范围和客观条件,选择开发一个单机版的贪吃蛇游戏。贪吃蛇游戏作为一款经典游戏,曾是诺基亚...
在Android系统上开发游戏,尤其是经典的贪吃蛇游戏,是一个很好的学习实践项目,它可以帮助开发者深入理解Android应用的基本架构、游戏循环机制以及图形绘制。这个"android系统上的贪吃蛇游戏源码"提供了完整的实现...
本文将深入解析这个Android贪吃蛇游戏的源代码,并探讨其核心概念和技术实现。 首先,让我们从游戏的基本框架开始。在Android应用开发中,通常会使用Activity作为应用程序的主要组件。在这个贪吃蛇游戏中,Activity...
通过分析这个Android贪吃蛇游戏的源码,我们可以学习到Android图形编程、事件处理、游戏循环、碰撞检测等多个方面的重要知识。理解并实践这些概念对于提升Android游戏开发技能非常有帮助。如果你想要深入研究,可以...
本资源是基于Android移动应用开发,用Android studio实现的期末作业,贪吃蛇小游戏。功能比较少,玩家可通过相应功能按键实现小游戏运行,碰到墙壁游戏结束 所使用配置: 1. Android studio 2022 Electric Eel(2022....
基于android的贪吃蛇游戏设计与开发.doc