博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Android 开发 -------- 自己定义View 画 五子棋
阅读量:5042 次
发布时间:2019-06-12

本文共 2346 字,大约阅读时间需要 7 分钟。

自己定义View  实现 五子棋 

配图:

代码:

package com.example.fiveson;import java.util.LinkedList;import java.util.List;import android.content.Context;import android.graphics.Canvas;import android.graphics.Color;import android.graphics.Paint;import android.util.AttributeSet;import android.view.MotionEvent;import android.view.View;public class FiveSon extends View {	public FiveSon(Context context) {		super(context);		// TODO Auto-generated constructor stub		init(context, null);	}	public FiveSon(Context context, AttributeSet attrs) {		super(context, attrs);		// TODO Auto-generated constructor stub		init(context, attrs);	}	public FiveSon(Context context, AttributeSet attrs, int defStyleAttr) {		super(context, attrs, defStyleAttr);		// TODO Auto-generated constructor stub		init(context, attrs);	}		private Paint paint = new Paint();	private Paint circlePaint = new Paint();		// 旗子: 信息  代表 第几行 第几列?	private List
chesses = new LinkedList
(); private void init(Context context, AttributeSet attrs) { chesses.add(new int[]{3,5}); chesses.add(new int[]{3,6}); } int spacing = 100; @Override protected void onDraw(Canvas canvas) { // TODO Auto-generated method stub super.onDraw(canvas); int width = getWidth(); int height = getHeight(); //1 绘制 X 坐标 int num = width / spacing; paint.setColor(Color.BLACK); for(int i=0;i<=num;i++) { canvas.drawLine(spacing*i, 0, spacing*i, height, paint); } num = height/spacing; for(int i=0;i<=num;i++) { canvas.drawLine(0,spacing*i, width,spacing*i, paint); } //2 绘制Y 坐标 //3 绘制 旗子 if(!chesses.isEmpty()) { int count = chesses.size(); for(int i=0;i
=(spacing/2)) { colcc++; } if(rowcc>=(spacing/2)) { rowcc++; } // 推断什么时候add int len = chesses.size(); if(len>0) { boolean has = false; for(int i = len-1;i>=0;i--) { int[] chs = chesses.get(i); if(rowNum == chs[0] && colNum == chs[1]) { has = true; break; } } if(!has) { chesses.add(new int[]{rowNum,colNum}); invalidate(); } }else { chesses.add(new int[]{rowNum,colNum}); invalidate(); } isComsumed = true; }else { isComsumed = super.onTouchEvent(event); } return super.onTouchEvent(event); } }

转载于:https://www.cnblogs.com/wzjhoutai/p/6745197.html

你可能感兴趣的文章
RijndaelManaged 加密
查看>>
Android 音量调节
查看>>
HTML&CSS基础学习笔记1.28-给网页添加一个css样式
查看>>
windows上面链接使用linux上面的docker daemon
查看>>
Redis事务
查看>>
Web框架和Django基础
查看>>
python中的逻辑操作符
查看>>
CSS兼容性常见问题总结
查看>>
HDU 1548 A strange lift (Dijkstra)
查看>>
每天一个小程序—0005题(批量处理图片大小)
查看>>
C# 启动进程和杀死进程
查看>>
tcp实现交互
查看>>
IIS的各种身份验证详细测试
查看>>
JavaScript特效源码(3、菜单特效)
查看>>
聊聊、Zookeeper Linux 单服务
查看>>
Linux常用命令总结
查看>>
yii模型ar中备忘
查看>>
C#线程入门
查看>>
CSS清除浮动方法
查看>>
JVM内存回收机制简述
查看>>