游戏结束弹出保存玩家姓名和分数的窗口,玩家输入姓名后点击确定保存到数据库中。玩家可以通过主界面的排行榜可以查看到分数从高到低排行的榜单。
建立一个玩家类用来处理玩家的信息,该类实现类序列化接口,实例可以被序列化便于数据的传递。代码如下:
Java代码
- package cn.com.cyj.mouse.enity;
-
- import java.io.Serializable;
-
-
-
-
-
- public class Gamer implements Serializable{
-
- private String name;
-
- private int score;
-
- public Gamer(String name, int score) {
- this.name = name;
- this.score = score;
- }
- public String getName() {
- return name;
- }
- public int getScore() {
- return score;
- }
- @Override
- public String toString() {
- return "Gamer [name=" + name + ", score=" + score + "]";
- }
- }
游戏窗口是一个Activity,将主题样式设置成Dialog即在清单文件中GameOver设置属性android:theme="@android:style/Theme.Dialog"。代码如下:
Java代码
- package cn.com.cyj.mouse.services;
-
- import android.content.Intent;
- import android.os.Bundle;
- import android.text.TextUtils;
- import android.view.View;
- import android.view.View.OnClickListener;
- import android.widget.Button;
- import android.widget.EditText;
- import android.widget.TextView;
- import android.widget.Toast;
- import cn.com.cyj.mouse.R;
- import cn.com.cyj.mouse.enity.Gamer;
- import cn.com.cyj.mouse.ui.BaseActivity;
- import cn.com.cyj.mouse.ui.MouseStart;
-
-
-
-
-
- public class GameOver extends BaseActivity {
-
- Button confirm;
-
- Button cancel;
-
- EditText name;
-
- TextView finalScore;
- Intent intent;
-
- int nowScore;
- @Override
- protected void onCreate(Bundle savedInstanceState) {
- super.onCreate(savedInstanceState);
- setContentView(R.layout.activity_gameover);
-
- init();
- intent = getIntent();
- nowScore = Integer.parseInt(intent.getStringExtra("score"));
-
- finalScore.setText(nowScore+"");
-
- this.setFinishOnTouchOutside(false);
- }
-
-
-
- private void init() {
- confirm = (Button) findViewById(R.id.confirm);
- cancel = (Button) findViewById(R.id.cancel);
- name = (EditText) findViewById(R.id.name);
- finalScore = (TextView) findViewById(R.id.finalscore);
-
-
-
- confirm.setOnClickListener(new MyOnClick());
- cancel.setOnClickListener(new MyOnClick());
- }
- class MyOnClick implements OnClickListener{
- @Override
- public void onClick(View v) {
- int id = v.getId();
- switch (id) {
- case R.id.confirm:
-
- if(!TextUtils.isEmpty(name.getText().toString())){
- Gamer gamer = new Gamer(name.getText().toString(), nowScore);
-
- MouseStart.controller.insert(gamer);
-
- finish();
- }else{
- Toast.makeText(GameOver.this, "姓名不能为空", Toast.LENGTH_SHORT).show();
- }
- break;
- case R.id.cancel:
- finish();
- break;
- default:
- break;
- }
-
- }
- }
- }
数据库中存储玩家的姓名和分数,建立MouseSqlite类通过继承SQLiteOpenHelper来建立数据库和处理数据库升级等操作。
Java代码
- package cn.com.cyj.mouse.database;
-
- import android.content.Context;
- import android.database.sqlite.SQLiteDatabase;
- import android.database.sqlite.SQLiteOpenHelper;
-
-
-
-
-
- public class MouseSqlite extends SQLiteOpenHelper {
-
- public MouseSqlite(Context context) {
- super(context, "gamer.db", null, 1);
-
- }
-
-
-
- @Override
- public void onCreate(SQLiteDatabase db) {
- db.execSQL("create table gamer (id integer primary key autoincrement, name varchar(20), score integer);");
- }
-
- @Override
- public void onUpgrade(SQLiteDatabase db, int arg1, int arg2) {
- }
- }
本游戏对数据库的操作主要有添加一条玩家信息和查询所有玩家信息,查询的时候按照分数从高到低排列。对数据库操作一定要关闭数据库。代码如下:
Java代码
- package cn.com.cyj.mouse.database;
-
- import java.util.ArrayList;
-
- import android.content.ContentValues;
- import android.content.Context;
- import android.database.Cursor;
- import android.database.sqlite.SQLiteDatabase;
- import cn.com.cyj.mouse.enity.Gamer;
-
-
-
-
-
- public class GamerDatabase {
-
- MouseSqlite mouseSqlite;
- SQLiteDatabase db;
-
- ArrayList<Gamer> gamerList;
- public GamerDatabase(Context context) {
- mouseSqlite = new MouseSqlite(context);
- }
-
-
-
-
-
- public Boolean insertGamer(Gamer gamer){
-
- db = mouseSqlite.getWritableDatabase();
-
- ContentValues values = new ContentValues();
- String name = gamer.getName();
- int score = gamer.getScore();
- values.put("name", name);
- values.put("score", score);
-
- long res = db.insert("gamer", null, values);
-
- db.close();
- if(res != -1)
- return true;
- return false;
- }
-
-
-
-
- public ArrayList<Gamer> queryGamerAll(){
-
- db = mouseSqlite.getReadableDatabase();
- gamerList = new ArrayList<Gamer>();
-
- Cursor cursor = db.query("gamer", null, null, null, null, null, "score desc");
- while(cursor.moveToNext()){
-
- String name = cursor.getString(cursor.getColumnIndex("name"));
-
- int score = cursor.getInt(cursor.getColumnIndex("score"));
- Gamer gamer = new Gamer(name, score);
-
- gamerList.add(gamer);
- }
-
- db.close();
- return gamerList;
- }
- }