1、主Activity
- <span style="font-size:18px;color:#3333ff;">package com.bison;
- import android.app.Activity;
- import android.content.pm.ActivityInfo;
- import android.os.Bundle;
- import android.view.Window;
- import android.view.WindowManager;
- /**
- * </span>
- <span style="font-size:18px;color:#3333ff;"> * @author Bison
- *
- */
- public class PukeActivity extends Activity {
- /** Called when the activity is first created. */
- @Override
- public void onCreate(Bundle savedInstanceState) {
- super.onCreate(savedInstanceState);
- // 这个事隐藏标题栏,不解释
- requestWindowFeature(Window.FEATURE_NO_TITLE);
- // 隐藏状态栏,你懂的
- getWindow().setFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN,
- WindowManager.LayoutParams.FLAG_FULLSCREEN);
- /*
- * 开始有考虑使屏幕上扑克的排列随屏幕的分辨率变动 结果貌似不好做,注释掉了 Display display =
- * getWindowManager().getDefaultDisplay(); int screenWidth =
- * display.getWidth(); int screenHeight = display.getHeight();
- */
- // 使用代码锁定横屏
- setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_LANDSCAPE);
- // setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_PORTRAIT);这个是竖屏
- setContentView(new GameView(this));
- }
- }</span>
2、牌桌页面
- <span style="color:#3333ff;">package com.bison;
- import android.content.Context;
- import android.graphics.Bitmap;
- import android.graphics.BitmapFactory;
- import android.graphics.Canvas;
- import android.graphics.Rect;
- import android.view.MotionEvent;
- import android.view.SurfaceHolder;
- import android.view.SurfaceView;
- import com.bison.utils.Person;
- /**
- *
- * @author Bison
- *
- */
- public class GameView extends SurfaceView implements SurfaceHolder.Callback {
- private FlushThread thread = null;// 刷帧线程
- private Bitmap sourceBitmap = null;// 扑克图片来源
- private Bitmap backgroundDesk = null;// 牌桌背景
- private Bitmap backgroundPuke = null;// 扑克背面
- private final Person person;
- private int pukeWidth = 0;// 扑克的宽
- private int pukeHeight = 0;// 扑克的高
- private int deskWidth = 0;// 牌桌的宽
- private int deskHeight = 0;// 牌桌的高
- private int left = 0;// 我自己首张牌左距离
- public GameView(Context context) {
- super(context);
- getHolder().addCallback(this);
- this.thread = new FlushThread(getHolder(), this);// 实例化线程
- initBitmap();// 实例化图片
- this.person = new Person();// 实例化Person类
- this.left = deskWidth / 2 - (16 * 25 + pukeWidth) / 2;// 左距开始时赋值
- }
- private void initBitmap() {// 初始化图片
- sourceBitmap = BitmapFactory.decodeResource(getResources(),
- R.drawable.smallcard);
- pukeWidth = sourceBitmap.getWidth() / 14;// 每张扑克的宽高
- pukeHeight = sourceBitmap.getHeight() / 4;
- backgroundDesk = BitmapFactory.decodeResource(getResources(),
- R.drawable.gameback2);
- deskWidth = backgroundDesk.getWidth();// 牌桌的宽高
- deskHeight = backgroundDesk.getHeight();
- backgroundPuke = BitmapFactory.decodeResource(getResources(),
- R.drawable.cardback);
- }
- @Override
- protected void onDraw(Canvas canvas) {
- // 绘制牌桌
- canvas.drawBitmap(backgroundDesk, 0, 0, null);
- personPaint(canvas, pukeWidth, pukeHeight);
- deskthreePukes(canvas, pukeWidth, pukeHeight);
- }
- /** 绘制每个玩家手里的牌 */
- public void personPaint(Canvas c, int pukeWidth, int pukeHeight) {
- Rect src = new Rect();
- Rect dst = new Rect();
- // 遍历数组
- for (int i = 0; i < 3; i++) {
- for (int j = 0; j < 17; j++) {
- if (i == 0) {// 左手边玩家,不用绘出正面
- // src = person.cardRect(person.person1[j], pukeWidth,
- // pukeHeight);
- // dst.set(10, j * 20, 10 + pukeWidth, j * 20 + pukeHeight);
- c.drawBitmap(backgroundPuke, 35, 85, null);
- }
- if (i == 1) {// 自己
- src = person.cardRect(person.person2[j], pukeWidth,
- pukeHeight);
- dst.set(left + j * 25, this.deskHeight - 20 - pukeHeight,
- left + j * 25 + pukeWidth, deskHeight - 20);
- c.drawBitmap(sourceBitmap, src, dst, null);
- }
- if (i == 2) {// 右手边玩家,同样不用绘出正面
- // src = person.cardRect(person.person3[j], pukeWidth,
- // pukeHeight);
- // dst.set(this.screenWidth - 10 - pukeWidth, j * 20,
- // this.screenWidth - 10, j * 20 + pukeHeight);
- c.drawBitmap(backgroundPuke, deskWidth - 35 - pukeWidth,
- 85, null);
- }
- }
- }
- }
- /** 绘制三张底牌 */
- private void deskthreePukes(Canvas c, int pukeWidth, int pukeHeight) {
- Rect src = new Rect();
- Rect dst = new Rect();
- for (int i = 0; i < 3; i++) {
- src = person.cardRect(person.threePukes[i], pukeWidth, pukeHeight);
- dst.set(280 + i * pukeWidth, 12, 280 + (i + 1) * pukeWidth,
- 12 + pukeHeight);
- c.drawBitmap(sourceBitmap, src, dst, null);
- }
- }
- @Override
- public boolean onTouchEvent(MotionEvent event) {
- // 正在研究点击弹出相应的扑克
- return super.onTouchEvent(event);
- }
- @Override
- public void surfaceChanged(SurfaceHolder holder, int format, int width,
- int height) {
- }
- @Override
- public void surfaceCreated(SurfaceHolder holder) {
- this.thread.setFlag(true);
- this.thread.start();
- }
- @Override
- public void surfaceDestroyed(SurfaceHolder holder) {
- boolean retry = true;
- this.thread.setFlag(false);
- while (retry) {
- try {
- thread.join();
- retry = false;
- } catch (InterruptedException e) {
- e.printStackTrace();
- }
- }
- }
- // 刷帧线程</span>
- <span style="color:#3333ff;"> class FlushThread extends Thread {
- private boolean flag = false;
- private final int span = 500;
- private final GameView gameView;
- private final SurfaceHolder holder;
- public FlushThread(SurfaceHolder holder, GameView gameView) {
- this.gameView = gameView;
- this.holder = holder;
- }
- @Override
- public void run() {
- Canvas canvas;
- while (this.flag) {
- canvas = null;
- try {
- canvas = this.holder.lockCanvas(null);
- synchronized (this.holder) {
- this.gameView.onDraw(canvas);
- }
- } finally {
- if (canvas != null) {
- this.holder.unlockCanvasAndPost(canvas);
- }
- }
- try {
- Thread.sleep(span);
- } catch (InterruptedException e) {
- e.printStackTrace();
- }
- }
- }
- public boolean isFlag() {
- return flag;
- }
- public void setFlag(boolean flag) {
- this.flag = flag;
- }
- }
- }
- </span>
3、相关实体类
扑克牌类:
- <span style="font-size:18px;color:#3333ff;">package com.bison.utils;
- import java.util.Random;
- /**
- * 生成一副洗好的牌,并且 设计为单例模式
- *
- * @author Bison
- *
- */
- public class Cards {
- // 声明一副扑克牌
- public int[] pukes = new int[54];
- private static Cards cardsInstance = null;
- private Cards() {
- setPuke();
- shuffle();
- }
- public static Cards getInstance() {
- if (cardsInstance == null) {
- cardsInstance = new Cards();
- }
- return cardsInstance;
- }
- /** 给54张扑克牌赋值 :1~54 */
- private void setPuke() {
- for (int i = 0; i < 54; i++) {
- pukes[i] = i + 1;
- }
- }
- /** 洗牌 */
- private void shuffle() {
- Random rdm = new Random();
- for (int i = 0; i < 54; i++) {
- // random.nextInt();是个前闭后开的方法:0~53
- int rdmNo = rdm.nextInt(54);
- int temp = pukes[i];
- pukes[i] = pukes[rdmNo];
- pukes[rdmNo] = temp;
- }
- }
- }
- </span>
玩家类:
- <span style="font-size:18px;color:#3333ff;">package com.bison.utils;
- import android.graphics.Rect;
- /**
- * 这个是玩家的实体类
- *
- * @author Bison
- *
- */
- public class Person {
- private final Cards mCards = Cards.getInstance();
- public int[] person1 = new int[17];
- public int[] person2 = new int[17];
- public int[] person3 = new int[17];
- // 余下三张属于地主的
- public int[] threePukes = new int[3];
- public Person() {
- personHold(mCards.pukes);
- }
- /** 分牌 */
- private void personHold(int[] pukes) {
- int k = 0;
- for (int i = 0; i < 3; i++) {
- if (i == 0) {
- for (int j = 0; j < 17; j++) {
- person1[j] = pukes[k++];
- }
- // 将其排序
- sort(person1);
- }
- if (i == 1) {
- for (int j = 0; j < 17; j++) {
- person2[j] = pukes[k++];
- }
- // 将其排序
- sort(person2);
- }
- if (i == 2) {
- for (int j = 0; j < 17; j++) {
- person3[j] = pukes[k++];
- }
- // 将其排序
- sort(person3);
- }
- }
- threePukes[0] = pukes[51];
- threePukes[1] = pukes[52];
- threePukes[2] = pukes[53];
- }
- /** 对每个玩家手里的牌排序:使用冒泡排序 */
- private void sort(int[] ary) {
- for (int i = 0; i < ary.length; i++) {
- for (int j = 0; j < ary.length - i - 1; j++) {
- if (ary[j] > ary[j + 1]) {
- int temp = ary[j];
- ary[j] = ary[j + 1];
- ary[j + 1] = temp;
- }
- }
- }
- }
- /**
- * 对应扑克所在图片上的位置
- * 1 5 9 ………… 53
- * 2 6 10 ………… 54
- * 3 7 11
- * 4 8 12
- */
- public Rect cardRect(int cardValue, int width, int height) {
- int x = 0, y = 0;
- if (cardValue % 4 == 0) {
- x = cardValue / 4 - 1;
- y = 4;
- } else {
- x = cardValue / 4;
- y = cardValue % 4;
- }
- int left = x * width;
- int top = (y - 1) * height;
- int right = (x + 1) * width;
- int bottom = (y) * height;
- return new Rect(left, top, right, bottom);
- }
- }
- </span>
PS:斗地主还是可以做成很复杂的。相关图片
Android --- 斗地主 [牌桌实现源码]的更多相关文章
-
Android斗地主棋牌游戏牌桌实现源码下载
本次给大家分享下Android斗地主棋牌游戏牌桌实现源码下载如下: 为了节约内存资源,每张扑克牌都是剪切形成的,当然这也是当前编程的主流方法. 1.主Activity package com.biso ...
-
ubuntu 14.04.5 编译Android 4.4.4 r1源码(最新)
本文博客链接:http://blog.csdn.net/qq1084283172/article/details/54426189 吐槽:ubuntu系统真是让人又爱又恨,也有可能是VMware Wo ...
-
Android Small插件化框架源码分析
Android Small插件化框架源码分析 目录 概述 Small如何使用 插件加载流程 待改进的地方 一.概述 Small是一个写得非常简洁的插件化框架,工程源码位置:https://github ...
-
android应用商店完整版源码
这个是从一个安卓学习的网站上转载过来的,android应用商店完整版源码,大家可以看看一下吧. _op><ignore_js_op> <ignore_js_op>< ...
-
Android版的疯狂猜图游戏源码完整版分享
这个游戏源码是在安装教程网那么分享过来的,Android版的疯狂猜图游戏源码完整版分享,也是本人之前很早以前发的一款游戏源码的,大家如果想了解一下,可以看看吧,不说多了,上一个图先吧. > ...
-
多种的android进度条的特效源码
多种的android进度条的特效源码,这个源码是在源码天堂那个网站上转载过来的,我已经修改一部分了,感觉很实用的,大家可以学习一下吧,我就不上传源码了,大家可以直接到那个网站上下载吧. 源码天堂下载地 ...
-
Android IntentService使用介绍以及源码解析
版权声明:本文出自汪磊的博客,转载请务必注明出处. 一.IntentService概述及使用举例 IntentService内部实现机制用到了HandlerThread,如果对HandlerThrea ...
-
Android源码浅析(三)——Android AOSP 5.1.1源码的同步sync和编译make,搭建Samba服务器进行更便捷的烧录刷机
Android源码浅析(三)--Android AOSP 5.1.1源码的同步sync和编译make,搭建Samba服务器进行更便捷的烧录刷机 最近比较忙,而且又要维护自己的博客,视频和公众号,也就没 ...
-
Android 7.1.1系统源码下载、编译、刷机-Nexus 6实战
想成为一位合格的Android程序员或者一位Android高级工程师是十分有必要知道Android的框架层的工作原理,要知道其工作原理那么就需要阅读Android的源代码. 想要阅读Android的源 ...
随机推荐
-
BestCoder Round #80 1002
HDU 5666 Segment 题意:给你条斜率为-1,常数项为q(q为质数)的直线,连接原点与直线上整数格点,问你在有多少个格点在形成的无数个三角形内,而不在线段上,结果对P取模. 思路:best ...
-
[py]简易pick lucky num程序
程序功能: 1,用户输入数字,当用户输入指定数字时候,输出他输入的循环那次 2,第二次询问是否还要输 3,如果no 则 终止 4,如果yes则继续输入 判断输入是否大于首次输入的 如果大于则开始循环输 ...
-
lnmp下配置虚拟主机
一:首先熟悉几个命令 which php ---> which是通过 PATH环境变量到该路径内查找可执行文件,所以基本的功能是寻找可执行文件 whereis php ----& ...
-
iso-开发基础知识-1-程序流程
main-应用程序委托-视图控制器 main()---主函数 应用程序委托 ---AppDelegate 视图控制器 ---ViewController - (BOOL)applicatio ...
-
T-SQL基础(2) - 单表查询
开窗函数over select orderid, custid, val, SUM(val) over() as totalvalue, SUM(val) over(partition by cust ...
-
《JAVA程序设计与实例》记录与归纳--继承与多态
继承与多态 概念贴士: 1. 继承,即是在已经存在的类的基础上再进行扩展,从而产生新的类.已经存在的类成为父类.超类和基类,而新产生的类成为子类或派生类. 2. Java继承是使用已存在的类的定义作为 ...
-
Java 并发学习笔记
并发 最近重新复习了一边并发的知识,发现自己之前对于并发的了解只是皮毛.这里总结以下Java并发需要掌握的点. 使用并发的一个重要原因是提高执行效率.由于I/O等情况阻塞,单个任务并不能充分利用CPU ...
-
Java抽象类总结规定
1. 抽象类不能被实例化(初学者很容易犯的错),如果被实例化,就会报错,编译无法通过.只有抽象类的非抽象子类可以创建对象. 2. 抽象类中不一定包含抽象方法,但是有抽象方法的类必定是抽象类. 3. 抽 ...
-
Django之用户认证组件
auth模块 之前我们在进行用户登录验证的时候,都是自己写代码,接收用户提交的数据,然后去数据库取数据进行匹配验证,其实Django已经给我们提供了内置的用户认证功能.不信的话你可以打开models. ...
-
iOS weak 内存释放问题
我们都知道weak 关键字可以解决内存不释放问题,但是使用上有些讲究. 看代码: import UIKit var str = "Hello, playground" class ...